我写了一个测试程序,它有两个进程。父进程从队列中获取数据,子进程将数据放入其中。有一个信号处理程序告诉程序退出。但是,当我将信号SIGTERM发送到我打印的pid(子进程)时,它有时不会退出,而且它似乎有一个死锁。
import os
import sys
import multiprocessing
import time
import signal
bStop = False
def worker(que):
signal.signal(signal.SIGTERM,sighandler)
print 'worker:',os.getpid()
for i in range(100000000):
que.put(i)
print 'STOP'
def sighandler(num,frame):
print 'catch signal'
q.put('STOP')
sys.exit(0)
q = multiprocessing.Queue(100)
p = multiprocessing.Process(target=worker,args=(q,))
p.start()
for item in iter(q.get,'STOP'):
print 'get',item
pass
print 'main stop'
p.join()
答案 0 :(得分:1)
除非你正在运行python 3,否则你应该使用xrange而不是range来表示一个大的循环。 Python一旦超过某个列表大小就会窒息,所以你真的需要在那时转移到生成器。
这很可能是你现在看到的问题。