C++调用Python传入回调函数

C++和Python混合编程

使用场景

  1. C++调用Python算法,而算法是在一个循环中分步计算结果,计算过程的中间结构要在UI上实时渲染;

传回调函数的原因

  1. 刚开始想在线程中做运算,然后把结果放到队列,主线程去取运算结果,测试Demo可行;但是,算法中用到了Numpy和sklearn的库,这两个库在线程中运算特别耗时,无法使用,最终选择了,传入回调函数的方式;

代码

  1. C++
#include <iostream>
#include <Python.h>
#include <exception>
using namespace std;

static PyObject* PointInfoBack(PyObject* self, PyObject*args)
{
	int nType = -1;
	PyObject * myobj = NULL;
	if (!PyArg_ParseTuple(args, "O", &myobj))
		return nullptr;
	int nSize = PyDict_Size(myobj);
	std::cout << "返回字典的大小为: " << nSize << std::endl;
	PyObject *pType = PyDict_GetItemString(myobj, "type");
	PyArg_Parse(pType, "i", &nType);
	std::cout << "Type: " << nType << std::endl;
	return Py_BuildValue("i", 1);
}

static PyMethodDef HahlibMethods[] = {
	{"PointsBack", PointInfoBack, METH_VARARGS, ""},
	{NULL, NULL, 0, NULL}
};

static PyModuleDef HashlibModule = {
	PyModuleDef_HEAD_INIT, "CppInterface", NULL, -1, HahlibMethods,
	NULL, NULL, NULL, NULL
};

static PyObject *PyInitCppInterface(void)
{
	return PyModule_Create(&HashlibModule);
}

int main()
{
	PyImport_AppendInittab("CppInterface", &PyInitCppInterface);

	Py_Initialize();
	PyRun_SimpleString("import sys");
	PyRun_SimpleString("sys.path.append('./')");

	PyObject * pModule = PyImport_ImportModule("testcall");      //Test001:Python文件名 
	PyObject* pFunc = PyObject_GetAttrString(pModule, "getILoomaAddress");


	/*PyObject* cons_args = PyTuple_New(1);
	PyTuple_SetItem(cons_args, 0, Py_BuildValue("s", "czx"));*/

	if (!pFunc || !PyCallable_Check(pFunc)) {
		return 0;
	}

	PyObject *obj = PyObject_CallObject(pFunc, NULL);
	if (!obj) {
		throw exception("obj not Create!");
	}
	
	Py_Finalize();

	system("pause");

	return 0;
}

  1. Python (testcall.py)
import CppInterface

def getILoomaAddress():
    print('getILoomaAddress')
    ret = {"status": 1, "type": 2, "vertices": [0, 1], "normals": [0, 1]}
    CppInterface.PointsBack(ret)
    return ret
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Python调用C++函数并传递ndarray数据,可以使用NumPy库将ndarray数据转换为C++中的数组类型。下面是一个示例代码,展示了如何在Python调用一个接受ndarray数据的C++函数: 假设我们有一个C++函数,它接受一个浮点型数组类型`float*`和数组的长度`int`: ```c++ #include <iostream> void my_function(float* data, int length) { for (int i = 0; i < length; i++) { std::cout << data[i] << " "; } std::cout << std::endl; } ``` 现在,我们可以在Python中使用NumPy库来创建一个ndarray数据,并将其传递给这个C++函数。下面是示例代码: ```python import numpy as np import ctypes # 加载C++编译后的动态链接库 lib = ctypes.cdll.LoadLibrary('./libexample.so') # 定义函数参数类型 lib.my_function.argtypes = [np.ctypeslib.ndpointer(dtype=np.float32, ndim=1), ctypes.c_int] # 创建一个ndarray数据,并将其传递给C++函数 data = np.array([1.0, 2.0, 3.0], dtype=np.float32) lib.my_function(data, len(data)) ``` 在上面的示例代码中,我们首先使用`cdll.LoadLibrary()`函数加载C++编译后的动态链接库。接着,我们使用`np.ctypeslib.ndpointer()`函数定义了C++函数的参数类型,其中`dtype`参数表示数组中元素的数据类型,`ndim`参数表示数组的维度。然后,我们将创建的ndarray数据`data`和数组的长度传递给C++函数`my_function()`。 需要注意的是,在传递ndarray数据时,需要正确地设置数据类型和维度。如果数据类型和维度设置不正确,可能会导致程序出错或结果不正确。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值