python线程停止isalive_Python是否正确地终止/退出未来线程?

我以前使用的是threading.Thread模块。现在我使用concurrent.futures->ThreadPoolExecutor。以前,我使用以下代码退出/终止/完成线程:def terminate_thread(thread):

"""Terminates a python thread from another thread.

:param thread: a threading.Thread instance

"""

if not thread.isAlive():

return

exc = ctypes.py_object(SystemExit)

res = ctypes.pythonapi.PyThreadState_SetAsyncExc(

ctypes.c_long(thread.ident), exc)

if res == 0:

raise ValueError("nonexistent thread id")

elif res > 1:

# """if it returns a number greater than one, you're in trouble,

# and you should call it again with exc=NULL to revert the effect"""

ctypes.pythonapi.PyThreadState_SetAsyncExc(thread.ident, None)

raise SystemError("PyThreadState_SetAsyncExc failed")

这似乎不适用于futures接口。这里的最佳实践是什么?只是return?我的线程正在控制Selenium实例。我需要确保当我杀死一个线程时,Selenium实例被销毁。在

编辑:我已经看到了一篇被引用为重复的帖子。这是不够的,因为当你冒险进入类似未来的东西时,行为可能会完全不同。在前一个线程模块的情况下,我的terminate_thread函数是可以接受的,不适用于对其他q/a的批评,它与“killing”是不一样的。请看一下我发布的代码。在

我不想杀人。我想检查它是否仍然存在,并以最适当的方式优雅地退出线程。期货怎么办?在

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值