使用python事件并与c++;
我正在测试在C/C++程序中嵌入Python,但我缺乏理解 测试程序很简单:使用python事件并与c++;,python,c++,python-embedding,Python,C++,Python Embedding,我正在测试在C/C++程序中嵌入Python,但我缺乏理解 测试程序很简单: 初始化解释器 从启动计时器的文件执行python脚本(每0.1秒增加一个变量) 等待5秒(C++) 从字符串执行python脚本,该字符串显示计时器事件生成的值 等待5秒(C++) 最后确定 我观察到计时器事件是在方法Py_FinalizeEx()的调用期间执行的 因此: 在PyjFielZeEXE()方法中停止C++程序; C++程序不能在PyrFielZeEXE()之前或之后与事件交互;李> 在事件循环中
- 初始化解释器李>
- 从启动计时器的文件执行python脚本(每0.1秒增加一个变量)李>
- 等待5秒(C++)李>
- 从字符串执行python脚本,该字符串显示计时器事件生成的值
- 等待5秒(C++)李>
- 最后确定李>
- 在PyjFielZeEXE()方法中停止C++程序;<李>
- C++程序不能在PyrFielZeEXE()之前或之后与事件交互;李>
在事件循环中C++程序如何与Python程序进行交互? python代码:
从线程导入*
计数=0;
def foo():
全局计数
t=计时器(0.1,foo)
t、 开始()
计数=计数+1;
打印(“foo”+str(计数),flush=True)
foo()
c++代码
//初始化
Py_初始值(0);
//执行foo.py
PyRun_SimpleStringFlags(“exec(open('foo.py'.encode('utf-8'))).read()”,nullptr);
//等5秒钟
qDebug()QTime::currentTime());
qDebug()伊卡洛斯的解决方案帮助了我:
用Py_begin_ALLOW_线程和Py_end_ALLOW_线程包围“wait begin”和“wait end”
这些宏对应于以下代码:
//Py\u BEGIN\u ALLOW\u线程
{
PyThreadState*保存
save=PyEval_SaveThread();
// -------------
qDebug()QTime::currentTime());
qDebug()用Py_begin_ALLOW_线程和Py_end_ALLOW_线程围绕“wait begin”和“wait end”
foo 1
wait 1 begin
wait 1 end
wait 2 begin
1
wait 2 end
finalize: begin
foo 2
foo 3
foo 4
foo 5
foo 6
foo 7
foo 8
foo 9
foo 10
from threading import *
count = 0;
def foo():
global count
if count < 20:
t = Timer(1, foo)
t.start()
count= count+1;
print("foo " + str(count), flush=True)
foo()
start: begin
foo 1
start: end
foo 2
foo 3
foo 4
foo 5
foo 6
read: begin
read: end
read6
foo 7
foo 8
foo 9
foo 10
read: begin
read: end
read10
foo 11
foo 12
foo 13
foo 14
foo 15
read: begin
read: end
read15
foo 16
foo 17
foo 18
foo 19
foo 20
read: begin
read: end
read20
foo 21
read: begin
read: end
read21
read: begin
read: end
read21
read: begin
read: end
read21
...