日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁(yè) > > 充電吧
[導(dǎo)讀]環(huán)境VS2005Python2.5.4 Windows XP SP3?簡(jiǎn)述一般開發(fā)過(guò)游戲的都知道Lua和C++可以很好的結(jié)合在一起,取長(zhǎng)補(bǔ)短,把Lua腳本當(dāng)成類似動(dòng)態(tài)鏈接庫(kù)來(lái)使用,很好的利用了腳本開發(fā)

環(huán)境

VS2005Python2.5.4 Windows XP SP3

?

簡(jiǎn)述

一般開發(fā)過(guò)游戲的都知道Lua和C++可以很好的結(jié)合在一起,取長(zhǎng)補(bǔ)短,把Lua腳本當(dāng)成類似動(dòng)態(tài)鏈接庫(kù)來(lái)使用,很好的利用了腳本開發(fā)的靈活性。而作為一門流行的通用型腳本語(yǔ)言python,也是可以做到的。在一個(gè)C++應(yīng)用程序中,我們可以用一組插件來(lái)實(shí)現(xiàn)一些具有統(tǒng)一接口的功能,一般插件都是使用動(dòng)態(tài)鏈接庫(kù)實(shí)現(xiàn),如果插件的變化比較頻繁,我們可以使用Python來(lái)代替動(dòng)態(tài)鏈接庫(kù)形式的插件(堪稱文本形式的動(dòng)態(tài)鏈接庫(kù)),這樣可以方便地根據(jù)需求的變化改寫腳本代碼,而不是必須重新編譯鏈接二進(jìn)制的動(dòng)態(tài)鏈接庫(kù)。靈活性大大的提高了。

?

Python/CAPI簡(jiǎn)介

通過(guò)C++調(diào)用Python腳本主要要用到如下的一些Python提供的API,因?yàn)閷?shí)際上C++要調(diào)用的是Python的解釋器,而Python解釋器本質(zhì)就是實(shí)現(xiàn)在動(dòng)態(tài)鏈接庫(kù)里面的,因此在調(diào)用前和調(diào)用后要進(jìn)行一些初始化和資源釋放的工作,另外,要調(diào)用Python腳本里面的函數(shù)等等東西,需要Python提供的一些特殊API來(lái)包裝C++調(diào)用。(可以參考[2])。

?

void Py_Initialize(void)

初始化Python解釋器,如果初始化失敗,繼續(xù)下面的調(diào)用會(huì)出現(xiàn)各種錯(cuò)誤,可惜的是此函數(shù)沒有返回值來(lái)判斷是否初始化成功,如果失敗會(huì)導(dǎo)致致命錯(cuò)誤。

?

int Py_IsInitialized(void)

檢查是否已經(jīng)進(jìn)行了初始化,如果返回0,表示沒有進(jìn)行過(guò)初始化。

?

void?Py_Finalize()

反初始化Python解釋器,包括子解釋器,調(diào)用此函數(shù)同時(shí)會(huì)釋放Python解釋器所占用的資源。

?

int PyRun_SimpleString(const char *command)

實(shí)際上是一個(gè)宏,執(zhí)行一段Python代碼。

?

PyObject* PyImport_ImportModule(char *name)

導(dǎo)入一個(gè)Python模塊,參數(shù)name可以是*.py文件的文件名。類似Python內(nèi)建函數(shù)import。

?

PyObject* PyModule_GetDict( PyObject *module)

相當(dāng)于Python模塊對(duì)象的__dict__屬性,得到模塊名稱空間下的字典對(duì)象。

?

PyObject* PyRun_String(const char* str, int start,PyObject* globals, PyObject* locals)

執(zhí)行一段Python代碼。

?

int PyArg_Parse(PyObject* args, char* format, ...)

把Python數(shù)據(jù)類型解析為C的類型,這樣C程序中才可以使用Python里面的數(shù)據(jù)。

?

PyObject* PyObject_GetAttrString(PyObject *o, char*attr_name)

返回模塊對(duì)象o中的attr_name?屬性或函數(shù),相當(dāng)于Python中表達(dá)式語(yǔ)句,o.attr_name。

?

PyObject* Py_BuildValue(char* format, ...)

和PyArg_Parse剛好相反,構(gòu)建一個(gè)參數(shù)列表,把C類型轉(zhuǎn)換為Python對(duì)象,使得Python里面可以使用C類型數(shù)據(jù)。

?

PyObject* PyEval_CallObject(PyObject* pfunc, PyObject*pargs)

此函數(shù)有兩個(gè)參數(shù),而且都是Python對(duì)象指針,其中pfunc是要調(diào)用的Python?函數(shù),一般說(shuō)來(lái)可以使用PyObject_GetAttrString()獲得,pargs是函數(shù)的參數(shù)列表,通常是使用Py_BuildValue()來(lái)構(gòu)建。

?

更多的API請(qǐng)參考官方的文檔,比較直觀簡(jiǎn)單,譬如怎樣初始化一個(gè)類實(shí)例,怎樣調(diào)用類成員函數(shù)。下面上點(diǎn)代碼,感受下這個(gè)過(guò)程。

?

C++代碼

#include?"stdafx.h"

#include?"Python.h"

?

int?_tmain(int?argc,?_TCHAR*?argv[])

{

???????int?nRet?= -1;

?

???????PyObject*?pName?=?NULL;

???????PyObject*?pModule?=NULL;

???????PyObject*?pDict?=?NULL;

???????PyObject*?pFunc?=?NULL;

???????PyObject*?pArgs?=?NULL;

???????PyObject*?pRet?=?NULL;

???????do

???????{

??????????????//?初始化Python

??????????????//?在使用Python系統(tǒng)前,必須使用Py_Initialize對(duì)其

??????????????//?進(jìn)行初始化。它會(huì)載入Python的內(nèi)建模塊并添加系統(tǒng)路

??????????????//?徑到模塊搜索路徑中。這個(gè)函數(shù)沒有返回值,檢查系統(tǒng)

??????????????//?是否初始化成功需要使用Py_IsInitialized。

??????????????Py_Initialize();

?

??????????????//?檢查初始化是否成功

??????????????if?(!Py_IsInitialized())

??????????????{

?????????????????????break;

??????????????}

?

??????????????//?添加當(dāng)前路徑

??????????????//?把輸入的字符串作為Python代碼直接運(yùn)行,返回

??????????????//?表示成功,-1表示有錯(cuò)。大多時(shí)候錯(cuò)誤都是因?yàn)樽址?/p>

??????????????//?中有語(yǔ)法錯(cuò)誤。

??????????????PyRun_SimpleString("importsys");

??????????????PyRun_SimpleString("sys.path.append('./')");

?

??????????????//?載入名為PyPlugin的腳本

??????????????pName?=?PyString_FromString("PyPlugin");

??????????????pModule?=?PyImport_Import(pName);

??????????????if?(!pModule)

??????????????{

?????????????????????printf("can't findPyPlugin.pyn");

?????????????????????break;

??????????????}

?

??????????????pDict?=?PyModule_GetDict(pModule);

??????????????if?(!pDict)

??????????????{

?????????????????????break;

??????????????}

?

??????????????//?找出函數(shù)名為AddMult的函數(shù)

??????????????pFunc?=?PyDict_GetItemString(pDict,?"AddMult");

??????????????if?(!pFunc?|| !PyCallable_Check(pFunc))

??????????????{

?????????????????????printf("can't findfunction [AddMult]n");

?????????????????????break;

??????????????}

?

??????????????pArgs?=?Py_BuildValue("ii", 12, 14);

??????????????PyObject*?pRet?=?PyEval_CallObject(pFunc,pArgs);

??????????????int?a?= 0;

??????????????int?b?= 0;

??????????????if?(pRet?&&?PyArg_ParseTuple(pRet,"ii", &a,&b))

??????????????{

?????????????????????printf("Function[AddMult] call successful a + b = %d, a * b = %dn",?a,?b);

?????????????????????nRet?= 0;

??????????????}

?

??????????????if?(pArgs)

?????????????????????Py_DECREF(pArgs);

??????????????if?(pFunc)

?????????????????????Py_DECREF(pFunc);

??????????????//?找出函數(shù)名為HelloWorld的函數(shù)

??????????????pFunc?=?PyDict_GetItemString(pDict,?"HelloWorld");

??????????????if?(!pFunc?|| !PyCallable_Check(pFunc))

??????????????{

?????????????????????printf("can't findfunction [HelloWorld]n");

?????????????????????break;

??????????????}

??????????????pArgs?=?Py_BuildValue("(s)",?"magictong");

??????????????PyEval_CallObject(pFunc,pArgs);

???????}?while?(0);

??????

???????if?(pRet)

??????????????Py_DECREF(pRet);

???????if?(pArgs)

??????????????Py_DECREF(pArgs);

???????if?(pFunc)

??????????????Py_DECREF(pFunc);

???????if?(pDict)

??????????????Py_DECREF(pDict);

???????if?(pModule)

??????????????Py_DECREF(pModule);

???????if?(pName)

??????????????Py_DECREF(pName);

???????Py_Finalize();

?

???????return?0;

}

?

Python代碼

#!/usr/bin/python

import?string

?

class?CMyClass:

???????def?HelloWorld(self):

print?'HelloWorld'

?

class?SecondClass:

???????def?invoke(self,obj):

obj.HelloWorld()

?

def?HelloWorld(strName):

print?"Hello ",?strName

?

def?Add(a,?b,?c):

return?a?+?b?+?c

?

def?AddMult(a,?b):

"""

"""

print?"in FunctionAddMult..."

print?a

print?b

return?a?+?b,?a?*?b

?

def?StringToUpper(strSrc):

return?string.upper(strSrc)

?

下面還有幾個(gè)比較重要的問(wèn)題需要解決,且聽慢慢道來(lái)。

?

C++怎么向Python傳遞參數(shù)

C++向Python傳參數(shù)是以元組(tuple)的方式傳過(guò)去的,因此我們實(shí)際上就是構(gòu)造一個(gè)合適的Python元組就可以了,要用到PyTuple_New,Py_BuildValue,PyTuple_SetItem等幾個(gè)函數(shù),其中Py_BuildValue可以有其它一些的替換函數(shù)。

PyObject*?pyParams?=?PyTuple_New(2);

???????PyObject*?pyParams1=?Py_BuildValue("i",5);

???????PyObject*?pyParams2=?Py_BuildValue("i",6);

???????PyTuple_SetItem(pyParams,0,?pyParams1);

???????PyTuple_SetItem(pyParams,1,?pyParams2);

???????pRet?=?PyEval_CallObject(pFunc,?pyParams);

<p style="color:rgb(57,57,57);font-family:Ve

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動(dòng)電源

在工業(yè)自動(dòng)化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動(dòng)力設(shè)備,其驅(qū)動(dòng)電源的性能直接關(guān)系到整個(gè)系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動(dòng)勢(shì)抑制與過(guò)流保護(hù)是驅(qū)動(dòng)電源設(shè)計(jì)中至關(guān)重要的兩個(gè)環(huán)節(jié),集成化方案的設(shè)計(jì)成為提升電機(jī)驅(qū)動(dòng)性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動(dòng)電源

LED 驅(qū)動(dòng)電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個(gè)照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動(dòng)電源易損壞的問(wèn)題卻十分常見,不僅增加了維護(hù)成本,還影響了用戶體驗(yàn)。要解決這一問(wèn)題,需從設(shè)計(jì)、生...

關(guān)鍵字: 驅(qū)動(dòng)電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動(dòng)電源的公式,電感內(nèi)電流波動(dòng)大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計(jì) 驅(qū)動(dòng)電源

電動(dòng)汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動(dòng)汽車的核心技術(shù)之一是電機(jī)驅(qū)動(dòng)控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動(dòng)系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動(dòng)汽車的動(dòng)力性能和...

關(guān)鍵字: 電動(dòng)汽車 新能源 驅(qū)動(dòng)電源

在現(xiàn)代城市建設(shè)中,街道及停車場(chǎng)照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢(shì)逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動(dòng)電源 LED

LED通用照明設(shè)計(jì)工程師會(huì)遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動(dòng)電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動(dòng)電源的電磁干擾(EMI)問(wèn)題成為了一個(gè)不可忽視的挑戰(zhàn)。電磁干擾不僅會(huì)影響LED燈具的正常工作,還可能對(duì)周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來(lái)解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動(dòng)電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動(dòng)電源

關(guān)鍵字: LED 驅(qū)動(dòng)電源 開關(guān)電源

LED驅(qū)動(dòng)電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動(dòng)LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動(dòng)電源
關(guān)閉