
运行时逻辑错误或异常是指程序在编译通过、能够正常启动执行但在运行过程中因逻辑缺陷或非法操作而引发的错误。你提到的两类典型问题除零错误ZeroDivisionError在数学运算中对整数或浮点数执行除以零操作如5 / 0Python 中会抛出ZeroDivisionError其他语言如 Java/C 可能导致未定义行为或运行时异常如 Java 的ArithmeticException。空指针异常NullPointerException / NullReferenceException在 Java、C# 等语言中当试图调用一个值为null的对象的方法或访问其字段时触发Python 中无严格“空指针”概念但类似行为表现为AttributeError如None.method()或TypeError如None 1需通过if obj is not None:等方式防御性编程。这类错误通常无法被编译器静态检测需依赖测试、代码审查、异常处理try...except/try...catch及空值检查等手段预防。# 示例防御性处理除零和空值defsafe_divide(a,b):ifb0:raiseValueError(除数不能为零)returna/bdefprocess_user(user):ifuserisNone:raiseValueError(用户对象不能为空)returnuser.name.upper()在 Python 中无法真正“全局捕获所有未处理异常”并完全阻止程序退出尤其是SystemExit、KeyboardInterrupt等特殊异常但可通过以下两种主流机制拦截绝大多数未被捕获的运行时异常实现统一日志记录、错误上报或优雅降级✅ 1. 使用sys.excepthook推荐捕获主线程未处理异常这是最常用、最标准的方式用于替换默认的异常处理器对主线程中所有未被try...except捕获的异常生效。importsysimporttracebackdefglobal_exception_handler(exc_type,exc_value,exc_traceback):print(❌ 全局捕获未处理异常)print(f类型:{exc_type.__name__})print(f信息:{exc_value})print(堆栈跟踪:)traceback.print_exception(exc_type,exc_value,exc_traceback)# 设置为全局异常处理器sys.excepthookglobal_exception_handler# 测试触发未捕获异常1/0# → 被 global_exception_handler 捕获并打印⚠️ 注意不捕获SystemExit、KeyboardInterrupt除非显式重写sys.excepthook并处理它们不适用于子线程子线程异常需单独处理。✅ 2. 使用threading.excepthookPython 3.8捕获子线程异常子线程中未捕获的异常不会触发sys.excepthook需单独设置importthreadingdefthread_exception_handler(args):print(f 子线程异常{args.exc_type.__name__}:{args.exc_value})traceback.print_exception(args.exc_type,args.exc_value,args.exc_traceback)threading.excepthookthread_exception_handler# 启动一个会出错的子线程threading.Thread(targetlambda:1/0).start()✅ 结合sys.excepthook threading.excepthook可覆盖主线程 所有普通子线程的未处理异常。❌ 不推荐/无效方式try: ... except Exception:在顶层if __name__ __main__:中 —— 仅包裹主模块代码无法覆盖异步回调、定时器、信号处理等场景signal.signal(signal.SIGSEGV, ...)等底层信号处理 —— Python 的ZeroDivisionError等不是由系统信号触发无效。✅ 进阶实践建议在生产环境如 Flask/FastAPI中应结合框架自身的错误处理机制如app.errorhandler(Exception)使用logging.exception()替代print确保异常写入日志文件避免在excepthook中引发新异常否则 Python 会回退到默认行为并终止。importlogging logging.basicConfig(filenameapp.log,levellogging.ERROR)defrobust_excepthook(exc_type,exc_value,exc_tb):logging.error(未捕获异常,exc_info(exc_type,exc_value,exc_tb))# 可选上报 Sentry / Prometheus / 发送告警...