Python Multiprocess问题流程无法启动

时间:2013-07-17 04:28:12

标签: python multiprocessing

我写了这段代码,我希望有一个主线程,它启动多个子进程,产生一个监听器线程,等待一个kill消息子进程工作,但是testprocess没有运行,没有任何错误的错误?

   from multiprocessing import Process, Pipe
   from threading import Thread
   import time

   Alive = True 

   def listener_thread(conn): #listens for kill from main 
        global Alive
        while True:
        data = conn.recv()
        if data == "kill":
           Alive = False #value for kill 
           break

    def subprocess(conn):
        t = Thread(target=listener_thread, args=(conn,))
        count = 0 
        t.start()
        while Alive:
              print "Run number = %d" % count
              count = count + 1 


    def testprocess(conn):
    t = Thread(target=listner_thread, args=(conn,))
    count = 0 
    t.start()
    while Alive:
          print "This is a different thread run = %d" % count
          count = count + 1

    parent_conn, child_conn = Pipe()
    p = Process(target=subprocess, args=(child_conn,))
    p2 = Process(target=testprocess, args=(child_conn,))
    runNum = int(raw_input("Enter a number: ")) 
    p.start()
    p2.start()
    time.sleep(runNum) 
    parent_conn.send("kill") #sends kill to listener thread to tell them when to stop
    p.join()
    p2.join()

1 个答案:

答案 0 :(得分:2)

testprocess中的拼写错误使函数提前退出。

listner_thread应为listener_thread

如果您注释掉subprocess相关代码并运行代码,您将看到以下错误:

Process Process-1:
Traceback (most recent call last):
  File "/usr/lib/python2.7/multiprocessing/process.py", line 258, in _bootstrap
    self.run()
  File "/usr/lib/python2.7/multiprocessing/process.py", line 114, in run
    self._target(*self._args, **self._kwargs)
  File "t.py", line 25, in testprocess
    t = Thread(target=listner_thread, args=(conn,))
NameError: global name 'listner_thread' is not defined