参考:
Python进阶之路 - Timeout | 超时中断 - 知乎 (zhihu.com)
写的很棒。文章来源:https://www.toymoban.com/news/detail-706844.html
这里只记录我摘取的封装的一个class:文章来源地址https://www.toymoban.com/news/detail-706844.html
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import ctypes
import threading
class ThreadKillOver(RuntimeError):
"""
线程杀死后的反馈
"""
def __init__(self):
RuntimeError.__init__(self, "ThreadKillOver")
class ThreadKiller(threading.Thread):
"""separate thread to kill TerminableThread"""
def __init__(self, target_thread, exception_cls, repeat_sec=2.0):
threading.Thread.__init__(self)
self.target_thread = target_thread
self.exception_cls = exception_cls
self.repeat_sec = repeat_sec
self.daemon = True
def run(self):
"""loop raising exception incase it's caught hopefully this breaks us far out"""
while self.target_thread.is_alive():
#ctypes.pythonapi.PyThreadState_SetAsyncExc是Python的ctypes库中的一个函数,
# 用于设置Python线程的异步异常。这个函数的第一个参数是一个C语言中的线程状态对象,
# 第二个参数是要抛出的异常。这个函数允许你在Python的C API层面控制线程的异常处理,
# 通常情况下,你不需要直接使用这个函数,而是让Python的异常处理机制自动处理。
ctypes.pythonapi.PyThreadState_SetAsyncExc(ctypes.c_long(self.target_thread.ident),
ctypes.py_object(self.exception_cls))
self.target_thread.join(self.repeat_sec)
class TerminableThread(threading.Thread):
"""a thread that can be stopped by forcing an exception in the execution context"""
def terminate(self, exception_cls=ThreadKillOver, repeat_sec=1.0):
"""
一个是exception_cls,这个的含义是,线程结束时会raise哪一种异常;
另一个是repeat_sec,这个的含义是,杀手每隔多长时间去确认一次线程有没有死亡。
如果repeat_sec为1,则线程杀手会每秒检查一次,如果线程还没死,就再杀一次,知道确认死亡为止。
"""
if self.is_alive() is False:
return True
killer = ThreadKiller(self, exception_cls, repeat_sec=repeat_sec)
killer.start()
到了这里,关于python强制停止线程学习的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!