
目前比较多的做法还是如下,出于担心未知异常、没有记录日志就退出子线程的情况下,在函数用一个大的 try-except 来进行 handle,或者是将主要逻辑放到 test_sth 中,使用 try-except 来捕获:
def run(): try: test_sth() ... except Exception: log_exception() Thread(target=run).start() 总感觉包裹一大块不太美观的样子,请问这样是最佳实践了吗?
1 jdhao 2020 年 9 月 9 日 via Android 线程里面捕获异常,返回运行成功与否的标志?住进程根据这个再做处理 |
2 black11black 2020 年 9 月 9 日 异常捕捉你肯定得 try except 啊,包裹一大块是肯定的,唯一不爽写法上的改变你可以用装饰器。 logging 会自动处理多线程相关,但是你这么搞线程自己处理异常而不是集中到主线程,完全没有控制,没什么意义 |
3 dongxiao 2020 年 9 月 9 日 via Android 使用装饰器,把捕获逻辑提取出来 |