python中os._exit() 和 sys.exit()的用法和区别,以及WEB项目调用后的日志打印问题
两者的区别
1、sys.exit()会引发一个异常:SystemExit,如果这个异常没有被捕获,那么python解释器将会退出。如果有捕获此异常的代码,那么这些代码还是会执行。捕获这个异常可以做一些额外的清理工作。0为正常退出,其他数值(1-127)为不正常,可抛异常事件供捕获。
2、os._exit()直接将python解释器退出,余下的语句不会执行。
如何使用
一般来说os._exit()用于在线程中退出,sys.exit()用于在主线程中退出。
日志打印问题
1、os._exit()直接将python解释器退出,如果涉及其他程序调用,日志可能不会打印。
比如:在CRT上执行程序,日志是打印的:
但是在WEB项目调用此程序是,在WEB界面却没有日志展示:
2、将程序的退出改为sys.exit()后,WEB正常打印日志:
在这里插入图片描述