我有一组任务要并行执行,但在它们结束时,我需要知道是否有任何线程抛出异常。我不需要直接处理异常,我只需要知道其中一个线程是否因异常而失败,这样我就可以干净地终止脚本
这是一个简单的例子:
#!/usr/bin/python
from time import sleep
from threading import Thread
def func(a):
for i in range(0,5):
print a
sleep(1)
def func_ex():
sleep(2)
raise Exception("Blah")
x = [Thread(target=func, args=("T1",)), Thread(target=func, args=("T2",)), Thread(target=func_ex, args=())]
print "Starting"
for t in x:
t.start()
print "Joining"
for t in x:
t.join()
print "End"
在“结束”之前,我想遍历线程,看看是否有任何失败,然后决定我是否可以继续执行脚本,或者我是否需要在此时退出。
我不需要拦截异常或停止其他线程,我只需要知道最后是否有任何失败。
原文由 Nathan Williams 发布,翻译遵循 CC BY-SA 4.0 许可协议
到线程上的
join()
调用返回时,线程的堆栈已展开并且所有有关异常的信息都已丢失。因此,不幸的是,您需要提供自己的异常注册机制; 这里 讨论了一些技巧。