Python 如何优雅地处理子线程异常?

2020-09-09 20:24:07 +08:00
 Te11UA

目前比较多的做法还是如下,出于担心未知异常、没有记录日志就退出子线程的情况下,在函数用一个大的 try-except 来进行 handle,或者是将主要逻辑放到 test_sth 中,使用 try-except 来捕获:

def run():
    try:
        test_sth()
        ...
    except Exception:
        log_exception()
Thread(target=run).start()

总感觉包裹一大块不太美观的样子,请问这样是最佳实践了吗?

2845 次点击
所在节点    Python
3 条回复
jdhao
2020-09-09 20:30:32 +08:00
线程里面捕获异常,返回运行成功与否的标志?住进程根据这个再做处理
black11black
2020-09-09 20:38:59 +08:00
异常捕捉你肯定得 try except 啊,包裹一大块是肯定的,唯一不爽写法上的改变你可以用装饰器。

logging 会自动处理多线程相关,但是你这么搞线程自己处理异常而不是集中到主线程,完全没有控制,没什么意义
dongxiao
2020-09-09 20:41:24 +08:00
使用装饰器,把捕获逻辑提取出来

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/705598

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX