• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            力為的技術博客

            聯系 聚合 管理
              154 Posts :: 1 Stories :: 561 Comments :: 0 Trackbacks

             一、問題:

            現在有一個C++類庫Mythma.dll,需要Python用戶也可以調用這些服務,所以需要用封裝其為Python擴展模塊Mythma.pyd。
            現在有可執行程序PythonConsole.exe,依賴Mythma.dll模塊,希望PythonConsole.exe可以調用Python腳本,所以PythonConsole.exe中需要嵌入Python解析器。

            此時,PythonConsole.exe既可以直接訪問Mythma.dll,又可以通過Python腳本訪問Mythma.dll。關系圖如下:


            二、實現
            1、假設Mythma.dll中的類為CHelloWorld

             

            class MythmaAPI CHelloWorld
            {
            public
            :
               CHelloWorld(
            void
            );
               
            ~CHelloWorld(void
            );

               
            void SetId(int nId) { m_Id = nId;}

               
            int  GetId() const return m_Id; }

            private:
               
            int
             m_Id;
            }
            ;

             

            2、用Boost.Python將C++模塊封裝,使得Python腳本可以調用C++的功能

                如:

            #include "HelloWorld.h"
            #include 
            <boost/python.hpp>
            using namespace boost::python;

            BOOST_PYTHON_MODULE(MythmaPy)
            {
               class_
            <CHelloWorld>("CHelloWorld")
                  .def(
            "SetId"&CHelloWorld::SetId)
                  .def(
            "GetId"&CHelloWorld::GetId)
                  ;
            }

            此時,可以用Python腳本訪問Mythma.dll中的類,axxscript.py文件中的內容為:

            #import MythmaPy
            from MythmaPy import *
            world 
            = CHelloWorld()
            world.SetId(
            100)
            print world.GetId()


             

            3、在C++程序里內嵌Python解析器,使得C++可以調用Python腳本

            建立一個控制臺程序PythonConsole.exe,用來嵌入Python解析器

            int main(int argc, char **argv)
            {
               
            // Initialize the interpreter
               Py_Initialize();

               
            if (python::handle_exception(exec_mythma))
               
            {
                  
            if (PyErr_Occurred())
                  
            {
                     BOOST_ERROR(
            "Python Error detected");
                     PyErr_Print();
                  }

                  
            else
                  
            {
                     BOOST_ERROR(
            "A C++ exception was thrown  for which "
                        
            "there was no exception translator registered.");
                  }

               }


               
            char ch;
               std::cin 
            >> ch;
               
            // Boost.Python doesn't support Py_Finalize yet, so don't call it!
               return boost::report_errors();
            }


            執行調用Python腳本的過程如下:

            void exec_mythma()
            {
               std::cout 
            << "exec extension module Mythma" << std::endl;

               python::dict global;
               python::
            object result = python::exec_file(
                  
            ".\\axxscript.py", global, global);


               python::
            object world = global["world"];
               CHelloWorld
            & py = python::extract<CHelloWorld&>(world) BOOST_EXTRACT_WORKAROUND;

               std::cout 
            << py.GetId() << std::endl;

               std::cout 
            << "success!" << std::endl;
            }


            三、癥狀


            通過執行PythonConsole.exe無法正常調用腳本,錯誤信息如下:


            假如直接運行腳本,結果正確。不知各位朋友發現問題的原因沒有?有什么解決方法?


            四、測試環境
            VS2008
            Python2.5
            Boost 1.38
            測試工程下載


            五:更新
            終于找到問題的原因,詳見這里
            posted on 2009-09-13 16:16 力為 閱讀(7183) 評論(2)  編輯 收藏 引用 所屬分類: 5. GP&STL&BOOSTTools

            評論

            # re: Boost.Python與C++互操作的問題(更新) 2010-06-09 18:10 iamonkey
            我正在用pyactivemq連接activemq,代碼如下:

            message = session.createMapMessage()
            message.setBytes('aaa', 'bbb')

            pydev 報出如下錯誤,好像是類型不對,就是說最后一個參數'bbb',不是std::vector<unsigned char類型,這種類型只有C語言有,我該如何處理?懇請各位大俠幫忙。

            MapMessage.setBytes(MapMessage, str, str)
            did not match C++ signature:
            setBytes(class cms::MapMessage {lvalue}, class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> >, class std::vector<unsigned char,class std::allocator<unsigned char> >)
              回復  更多評論
              

            # re: Boost.Python與C++互操作的問題(更新)[未登錄] 2010-06-11 11:08 力為
            @iamonkey
            用個Python的數組試一下吧。
            'bbb'估計按照string來處理了  回復  更多評論
              

            久久青青国产| 亚洲精品无码久久久久| 久久99精品国产麻豆不卡| 久久国产精品一区| 囯产精品久久久久久久久蜜桃| 国产精品一区二区久久精品涩爱| 性高湖久久久久久久久AAAAA | 久久香蕉超碰97国产精品| av午夜福利一片免费看久久| 日本国产精品久久| 99精品久久精品一区二区| 日本国产精品久久| 青青青伊人色综合久久| 亚洲综合伊人久久综合| 久久国产精品一区二区| 亚洲精品乱码久久久久久蜜桃图片| 久久不射电影网| 精品久久亚洲中文无码| 精品一久久香蕉国产线看播放| 久久精品aⅴ无码中文字字幕不卡| 国产99久久九九精品无码| 久久r热这里有精品视频| 亚洲成色www久久网站夜月| 日日狠狠久久偷偷色综合免费| 2020最新久久久视精品爱 | 国产亚洲欧美成人久久片 | 国产精品久久久久免费a∨| 久久国产成人精品国产成人亚洲| 人人狠狠综合久久88成人| 亚洲国产美女精品久久久久∴| 久久av免费天堂小草播放| 亚洲午夜精品久久久久久人妖| 成人综合伊人五月婷久久| 久久午夜无码鲁丝片| 亚洲国产精品无码成人片久久| 久久精品国产亚洲AV香蕉| 一97日本道伊人久久综合影院| 久久夜色精品国产www| 人妻无码αv中文字幕久久琪琪布| 国产精品伊人久久伊人电影| 国产精品va久久久久久久|