python作为一门脚本解释语言,本身又很好的结合c++,所以使用python开发,在性能要求的地方调用c/c++底层库,这简直是神器。本文详细介绍了python调用c/c++底层库,互相传值问题,下面一起来看看。
前言
开发环境:
centos 7 + python 3.5.1 + qt creator(只是使用qt creator编译而已,并没有使用qt的任何库)
python调用c/c++库,我现在能做到的有两种方式
1.extern “c” 导出(互相传值比较麻烦,不建议使用这种方式):
将c/c++库做成和平常一样的dll和或者.so,比如:
//.h文件
#include
//.cpp文件
//c/c++ my.so 或者my.dll
enter “c” void printhello()
{
std::cout>1
#由于对python不是特别的熟悉 怎么也做不到显示c++返回的字符串, python只能显示c++返回的字符串子能看到一个地址而已
2.python扩展c/c++
不多说,直接上代码
//.h文件 本来这是c++连接mysql 我只摘抄部分代#include
//.cpp文件
//传递多个参数 python传过来的参数在args里面
pyobject* printfhello(pyobject* self,pyobject* args)
{
int i=0
const char* str;
if (!pyarg_parsetuple(args, “i|s”, &i,&str)) //i 表示整形 s 表示字符串
return pylong_fromlong(0);
print(“%d,%s”,i,str);
return py_buildvalue(“s”,”ok”); //向python返回ok字符串
}
//映射 知道mfc的一看就懂
static pymethoddef mymethods[] = {
{“printfhello”, printfhello, meth_varargs, //”printhello” 中可调用的函数 meth_varargs :带有参数 meth_noargs:无参数
“print”}, //说明
{“connect”, connect, meth_varargs,
“connect mysql”},
{null, null, 0, null}
};
static pyobject* utilerror;
// 向python中注册模块
static struct pymoduledef spammodule = {
pymoduledef_head_init,
“libmysqlutil”, //模块名字 import libmysqlutil
“c++ connect mysql”,
-1,
mymethods
};//pyinit_libmysqlutil 注意名字 一定要pyinit_ 加上你的模块名字 不然python import 会提示没有定义 pyinit_你的模块名字 pymodinit_func pyinit_libmysqlutil(void) { pyobject* m = nullptr; m = pymodule_create(&spammodule);
//m= py_initmodule(….) python 2.7 if(!m) { return m; } utilerror = pyerr_newexception(“util.error”,null,null); py_incref(utilerror); pymodule_addobject(m,”error”,utilerror); return m; }
#python
import libmysqlutil
libmysqlutil.printhello(1,”hello world”)
>>>1,hello world
>>>ok
总结
到目前为止python和c/c++互相通信,能适应大部分需求,结构体传值还没有研究,对于类,使用指针就行,c++里面是指针,在python中会将指针转化成整形,python将这个整形传给c++的时候使用pyarg_parsetuple又将整形会变成类指针。
更多详解python如何调用c/c++底层库与互相传值相关文章请关注php中文网!