您的理解是正确的:调用
Pyeval_InitThreads确实可以获取GIL。在正确编写的Python /
C应用程序中,这不是问题,因为GIL将自动或手动及时解锁。
如果主线程继续运行Python代码,则没有什么特别的事情,因为Python解释器将在执行了许多指令后自动放弃GIL(允许另一个线程来获取它,它将再次放弃它,依此类推)上)。另外,每当Python要调用阻塞系统调用时(例如,从网络读取或写入文件),它将在调用周围释放GIL。
这个答案的原始版本到此为止。但是还有另外一件事要考虑: 嵌入 方案。
嵌入Python时,主线程通常会初始化Python并继续执行其他与Python不相关的任务。在那种情况下,没有什么东西会 自动
释放GIL,因此必须由线程本身完成。这绝不是特定于call的调用
Pyeval_InitThreads,它是在使用获取的GIL调用的所有Python /
C代码中所期望的。
例如,
main()可能包含以下代码:
Py_Initialize();Pyeval_InitThreads();Py_BEGIN_ALLOW_THREADS... call the non-Python part of the application here ...Py_END_ALLOW_THREADSPy_Finalize();
如果您的代码是手动创建线程的,则它们需要先获取GIL,然后再进行与Python相关的 任何操作
,甚至简单到
Py_INCREF。为此,请使用以下命令:
// Acquire the GILPyGILState_STATE gstate;gstate = PyGILState_Ensure();... call Python pre here ...// Release the GIL. No Python API allowed beyond this point.PyGILState_Release(gstate);



