• <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 力為 閱讀(7194) 評論(2)  編輯 收藏 引用 所屬分類: 5. GP&STL&BOOST 、Tools

            評論

            # 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來處理了  回復  更多評論
              

            久久久久免费视频| 亚洲国产精品无码久久98| 亚洲国产精品无码久久一线| 91精品日韩人妻无码久久不卡| 国产成人精品久久| 精品久久久久久无码专区| 精品久久久久久中文字幕大豆网| 久久久人妻精品无码一区| 香蕉久久夜色精品国产2020| 久久av免费天堂小草播放| 亚洲色欲久久久久综合网| 亚洲色婷婷综合久久| …久久精品99久久香蕉国产| 久久男人Av资源网站无码软件 | 久久se精品一区二区影院| 久久久久国产精品麻豆AR影院| 久久精品国产亚洲一区二区三区| 久久久久香蕉视频| 狠狠色丁香久久综合五月| 国产精品欧美久久久久无广告| 性高朝久久久久久久久久| 色综合久久久久无码专区| 久久成人国产精品一区二区| 久久精品国产精品亜洲毛片 | 亚洲精品第一综合99久久| 国产精品久久久久影院色| 性高朝久久久久久久久久| AV无码久久久久不卡网站下载| 久久免费99精品国产自在现线 | 久久天堂电影网| 久久精品国产亚洲AV无码麻豆| 久久夜色精品国产| 精品久久久久久国产三级| 久久久无码精品亚洲日韩京东传媒 | 青青草国产97免久久费观看| 欧美无乱码久久久免费午夜一区二区三区中文字幕 | 久久久久这里只有精品| 一本一本久久a久久综合精品蜜桃| 久久亚洲国产午夜精品理论片| 日本人妻丰满熟妇久久久久久| 久久久久亚洲精品无码网址|