多线程环境下Python中的Kill挂起函数
我想杀死一个执行时间过长的函数。重要的是这个函数在C扩展内部(用Cython包装),我希望这个解决方案能够在多线程环境中工作。因为它是用Cython包裹的,所以这根线可以容纳GIL 我无法控制这个扩展内部发生的事情(我认为这段代码不会响应中断) 我相当肯定这段代码只会在Unix机器上运行。但这个问题并不适用,因为我认为信号在多线程环境中不起作用(好吧,还没有定义哪个线程将捕获它们)——但我可能在这一点上错了:),所以请纠正我多线程环境下Python中的Kill挂起函数,python,multithreading,cython,cpython,Python,Multithreading,Cython,Cpython,我想杀死一个执行时间过长的函数。重要的是这个函数在C扩展内部(用Cython包装),我希望这个解决方案能够在多线程环境中工作。因为它是用Cython包裹的,所以这根线可以容纳GIL 我无法控制这个扩展内部发生的事情(我认为这段代码不会响应中断) 我相当肯定这段代码只会在Unix机器上运行。但这个问题并不适用,因为我认为信号在多线程环境中不起作用(好吧,还没有定义哪个线程将捕获它们)——但我可能在这一点上错了:),所以请纠正我 我有没有办法在不产生新进程的情况下解决这个问题 我的解决方案是将此函数
我有没有办法在不产生新进程的情况下解决这个问题 我的解决方案是将此函数包装到另一个python进程中,并在需要时终止该进程 给谷歌搜索这个问题的人一条建议:由于进程启动时间(启动解释器,加载模块,然后将数据加载到内存)可能会持续几秒钟,所以您需要对函数调用进行分组,这样开销就不会增加;我不会杀了你(所以实际上没有可重用的解决方案)
示例解决方案已发布到na另一个问题: 看看答案。一般来说:没有,没有安全的方法。我怀疑这可能是一个难题。相关: