参见英文答案 >
PyEval_InitThreads in Python 3: How/when to call it? (the saga continues ad nauseam)7个
当我应该调用PyEval_InitThreads时,我有点困惑.通常,我知道只要使用非Python线程(即在扩展模块中生成的线程),就必须调用PyEval_InitThreads.
当我应该调用PyEval_InitThreads时,我有点困惑.通常,我知道只要使用非Python线程(即在扩展模块中生成的线程),就必须调用PyEval_InitThreads.
但是,如果PyEval_InitThreads用于嵌入Python解释器的C程序,或导入C扩展模块的Python程序,或者两者兼而有之,我会感到困惑.
因此,如果我编写一个内部启动线程的C扩展模块,在初始化模块时是否需要调用PyEval_InitThreads?
此外,PyEval_InitThreads implicitly acquires the Global Interpreter Lock.因此,在调用PyEval_InitThreads之后,可能必须释放GIL或者随后发生死锁.那么你如何释放锁?阅读文档后,PyEval_ReleaseLock()
似乎是释放GIL的方法.但是,实际上,如果我在C扩展模块中使用以下代码:
PyEval_InitThreads(); PyEval_ReleaseLock();
…然后在运行时Python中止:
Fatal Python error: drop_gil: GIL is not locked
那么在使用PyEval_InitThreads获取GIL后如何释放GIL?