今天写的一段代码需要用到进程multiprocessing,这个哥们比较任性,用Ctrl+C无法退出,当程序跑完之后又给我报了一段错误 我也是醉了。
然后我百度了一下发现了线程的另一个函数multiprocessing.join(),这个join不管是不是尸体,只要父进程死了,都直接回收。把他加上,又试了一下
错误信息竟然少了,然而剩下的这个错误信息怎么也不消失,即使用try也没用。看着join我突然想到C语言中也有这个函数,那是不是也可以用c中的signal呢,于是我加上了这 signal.signal(signal.SIGINT, CtrlC)
这一段代码 果然天从人愿 问题完美解决了!
完整代码如下:
def test1():
while True:
time.sleep(1)
def test2():
while True:
time.sleep(1)
def ctrl_c(signalnum, frame):
# 如果用sys.exit()会报系统异常达不到直接结束程序的效果。
# 因为sys.exit()触发的是系统异常,Exception只能捕获由代码触发的异常。
# 即使如此也不推荐使用sys.exit来结束进程,
# 因为Ctrl-C退出的时候需要按三次才能完全退出(和进程数无关)
os._exit(0)
try:
signal.signal(signal.SIGINT, ctrl_c) # 捕获singint信号,交给ctrl_c处理
signal.signal(signal.SIGTERM, ctrl_c)
t1 = multiprocessing.Process(target=test1)
t2 = multiprocessing.Process(target=test2)
t1.start()
t2.start()
t1.join()
t2.join()
except Exception,ex:
print ex
except SystemExit as se:
# 捕获系统异常
pass
while True:
time.sleep(10)
使用signal目的在于捕获kill发出的信号来执行不同的操作,比如更改日志级别,kill -9时可以自定义退出操作等等。