用于多处理的Python信号



我想在多线程python程序中执行某个信号处理程序。我注意到我的信号处理程序是为主线程和我创建的另一个线程(thread_1)调用的。是否有任何方法可以只对thread_1执行信号处理程序?或者有什么方法可以知道调用信号处理程序的线程的线程ID吗?是主线程还是线程_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

正如您所知,处理程序被调用了两次(一次用于主线程,另一次用于线程_1),正如我上面所问的,我想只执行线程_1的处理程序,甚至想找到一种方法来获取调用线程的线程id?

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

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

如果您确实切换到线程化实现,那么只有主线程会收到信号,您的问题将变得毫无意义。

最新更新