boost::python库是pyhon和c++相互交互的框架,可以再python中调用c++的类和方法,也可以让c++调用python的类和方法
python自身提供了一个Python/C API用来实现python和c++的交互,boost::python是Python/C API的包装,所以用起来更简单一些。
Python对一个动态类型的语言,C++是一个静态类型的语言,对于Python中的变量类型,Boost.Python都有相应的类对应,他们都是boost::python::object的子类。boost::python::object 包装了PyObject *, 通过这种方式c++可以平滑的操作python对象。Boost.Python的主要目标既保持Python的编程风格同时又提供C++和Python的双向映射。
python代码:
def f(x, y):
if(y =='foo'):
x[3:7]='bar'
else:
x.items += y(3, x)
return x
def getfunc():
return f;
c++重写代码
object f(object x, object y){
if(y =="foo")
x.slice(,)="bar";
else
x.attr("items")+= y(, x);
return x;
}
object getfunc(){
return object(f);
}
Python::Object是一个抽象父类,对Python的每个类型都实现了一个对应的子类。
- list
- dict
- tuple
- str
- long_
- enum
Python::Object对应一个Python对象,那么c++怎么获取Python对象的值呢,这个需要使用Python::extract方法
double d=python::extract<double>(obj)
通过PyObject*构造一个boost::python::object对象。
boost::python::object o(boost::python::handle<>(pyobj));
这样情况下. o管理pyobj, 不会增加pyobj的引用计数。
boost::python::object o(boost::python::handle<>(boost::python::borrowed(pyobj)));
这中情况下,会调用
Py_INCREF ,当O对象生命周期结束 ,pyobj不会析析构掉
怎么从python::object对象中获取PyObject* :
obj.ptr()