用于多线程的python信号

时间:2013-07-17 15:33:46

标签: multithreading python-2.7 signals

我想在多线程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?

1 个答案:

答案 0 :(得分:1)

信号在两个独立的进程中处理,而不是在单个进程的两个不同的线程中处理。 (提示:您import multiprocessing而不是import threading。)

子进程继承SIGINT的信号处理程序并获取自己的x副本。现在,shell在前台进程组中运行父进程和子进程,并将键盘生成的信号(如Ctrl-C => SIGINT)发送到整个进程组,这就是父进程和子进程都接收信号的原因。然后,父母和孩子都打印自己的x值。

如果你切换到线程实现,那么only the main thread将收到信号,你的问题将没有实际意义。