我想在多线程python程序中执行某些信号处理程序。 我注意到我的信号处理程序是为主线程和我创建的另一个线程(thread_1)调用的。 反正只为thread_1执行信号处理程序吗? 或者无论如何知道信号处理程序的调用线程的线程ID?是主线程还是thread_1?
import signal
import sys
from multiprocessing import Process
from time import sleep
x = 3;
def f(name):
print 'hello', name
while(1):
sleep (1)
print "AAAAAAAAAAAAAAAAAAAAAAAAA"
def signal_handler(signal, frame):
global x
print 'You pressed Ctrl+C!'
print x
sys.exit(0)
if __name__ == '__main__':
signal.signal(signal.SIGINT, signal_handler)
print 'Creating thread'
p = Process(target=f, args=('bob',))
p.start()
print 'Press Ctrl+C'
x += 6
signal.pause()
print 'After press CTRL+C'
得到了输出:
Creating thread
Press Ctrl+C
hello bob
AAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAAAAAAAAAAAAAAAAA
^CYou pressed Ctrl+C!
You pressed Ctrl+C!
9
3
因为你可以信号处理程序被调用两次(一个用于主线程,另一个用于thread_1),正如我上面提到的,我想只为thread_1执行处理程序,或者甚至找到一种方法来获取调用线程的thread_id?
答案 0 :(得分:1)
信号在两个独立的进程中处理,而不是在单个进程的两个不同的线程中处理。 (提示:您import multiprocessing
而不是import threading
。)
子进程继承SIGINT的信号处理程序并获取自己的x
副本。现在,shell在前台进程组中运行父进程和子进程,并将键盘生成的信号(如Ctrl-C => SIGINT)发送到整个进程组,这就是父进程和子进程都接收信号的原因。然后,父母和孩子都打印自己的x
值。
如果你切换到线程实现,那么only the main thread将收到信号,你的问题将没有实际意义。