C++子线程中调用python代码

3 篇文章 0 订阅

项目需要C++调用python的算法,由于python算法比较耗时,因此采用在C++里启动working thread来调用python脚本,python代码里含有cv2.imread()等opencv的调用,在子线程里调用会卡死。

解决办法:

//1,主线程初始化python时,需要使能多线程:
Py_Initialize();
PyEval_InitThreads(); 

//2,主线程中,创建子线程之前:
Py_BEGIN_ALLOW_THREADS
// 创建子线程并执行子线程
Py_END_ALLOW_THREADS

//3,子线程中:
void workingThread()
{
    PyGILState_STATE ret = PyGILState_Ensure();
    // 代码逻辑,包括调用python脚本
    PyGILState_Release(ret);
}

Python,可以使用thread模块或者threading模块来实现多线程编程。在多线程编程,每个线程都有自己的代码执行流程和堆栈空间,但是它们共享进程的资源,如全局变量、文件、socket等。 如果要在多线程调用Python解释器,可以使用Py_NewInterpreter()函数来创建一个新的解释器对象,并在这个解释器对象执行Python代码。 以下是一个示例代码: ``` import threading import ctypes import sys # 定义一个线程函数 def thread_func(): # 创建一个新的解释器对象 ctypes.pythonapi.Py_NewInterpreter() # 在新的解释器对象执行Python代码 exec("print('Hello from new interpreter')") # 释放解释器对象 ctypes.pythonapi.Py_EndInterpreter() # 在主线程创建一个新的线程 t = threading.Thread(target=thread_func) t.start() # 在主线程执行Python代码 print('Hello from main interpreter') ``` 在上面的代码,我们首先导入了threading模块和ctypes模块。然后定义了一个线程函数thread_func(),在这个函数创建了一个新的解释器对象,并在这个解释器对象执行了一段Python代码。最后,在主线程创建了一个新的线程,执行了一段Python代码,并输出了一些信息。 注意,在使用Py_NewInterpreter()函数创建一个新的解释器对象后,我们需要在新的解释器对象执行一些Python代码,否则这个解释器对象会很快被释放。在上面的代码,我们使用了exec()函数来执行一段简单的Python代码,你可以根据自己的需要来编写更复杂的代码
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值