前言
大家都知道Python的優(yōu)點(diǎn)是開發(fā)效率高,使用方便,C++則是運(yùn)行效率高,這兩者可以相輔相成,不管是在Python項(xiàng)目中嵌入C++代碼,或是在C++項(xiàng)目中用Python實(shí)現(xiàn)外圍功能,都可能遇到Python調(diào)用C++模塊的需求,下面列舉出集中c++代碼導(dǎo)出成Python接口的幾種基本方法,一起來(lái)學(xué)習(xí)學(xué)習(xí)吧。
原生態(tài)導(dǎo)出
Python解釋器就是用C實(shí)現(xiàn),因此只要我們的C++的數(shù)據(jù)結(jié)構(gòu)能讓Python認(rèn)識(shí),理論上就是可以被直接調(diào)用的。我們實(shí)現(xiàn)test1.cpp如下
#include <Python.h>int Add(int x, int y){ return x + y;}int Del(int x, int y){ return x - y;}PyObject* WrappAdd(PyObject* self, PyObject* args){ int x, y; if (!PyArg_ParseTuple(args, "ii", &x, &y)) { return NULL; } return Py_BuildValue("i", Add(x, y));}PyObject* WrappDel(PyObject* self, PyObject* args){ int x, y; if (!PyArg_ParseTuple(args, "ii", &x, &y)) { return NULL; } return Py_BuildValue("i", Del(x, y));}static PyMethodDef test_methods[] = { {"Add", WrappAdd, METH_VARARGS, "something"}, {"Del", WrappDel, METH_VARARGS, "something"}, {NULL, NULL}};extern "C"void inittest1(){ Py_InitModule("test1", test_methods);}
編譯命令如下
g++ -fPIC -shared test1.cpp -I/usr/include/python2.6 -o test1.so
運(yùn)行Python解釋器,測(cè)試如下
>>> import test1>>> test1.Add(1,2)3
這里要注意一下幾點(diǎn)
nm test1.so
查看函數(shù)符號(hào),c++filt工具可通過(guò)符號(hào)反解出函數(shù)原型通過(guò)boost實(shí)現(xiàn)
我們使用和上面同樣的例子,實(shí)現(xiàn)test2.cpp如下
#include <boost/python/module.hpp>#include <boost/python/def.hpp>using namespace boost::python;int Add(const int x, const int y){ return x + y;}int Del(const int x, const int y){ return x - y;}BOOST_PYTHON_MODULE(test2){ def("Add", Add); def("Del", Del);}
其中BOOST_PYTHON_MODULE的參數(shù)為要導(dǎo)出的模塊名字
編譯命令如下
g++ test2.cpp -fPIC -shared -o test2.so -I/usr/include/python2.6 -I/usr/local/include -L/usr/local/lib -lboost_python
注意: 編譯時(shí)需要指定boost頭文件和庫(kù)的路徑,我這里分別是/usr/local/include和/usr/local/lib
或者通過(guò)setup.py導(dǎo)出模塊
#!/usr/bin/env pythonfrom distutils.core import setupfrom distutils.extension import Extensionsetup(name="PackageName", ext_modules=[ Extension("test2", ["test2.cpp"], libraries = ["boost_python"]) ])
新聞熱點(diǎn)
疑難解答
圖片精選