每一个process对象最多只能调用一次start()方法,join([timeout])方法会阻塞调用process对象的进程,直到timeout时间超时,或者process进程退出。若是timeout设置为None,则无超时时间。对于linux操做系统的进程管理,父进程会等待子进程退出,并收回子进程的资源,而后父进程再退出。若是父进程先于子进程退出,则子进程会被init进程接管。若是父进程没有退出也没有回收子进程资源,则子进程会一直停留在僵死状态。这里join方法就是阻塞父进程,等待子进程执行完毕。linux
若是在子进程里面要接受标准输入(如调用raw_input函数),这时候会有问题。由于标准输入是被父进程占用,所以这里子进程没法从标准输入读取数据。ide
一个解决办法是将标准输入描述符,传入子进程函数:函数
from multiprocessing import Processui
import sys, osspa
import time操作系统
def intask(x, fileno):orm
sys.stdin = os.fdopen(fileno)对象
while True:进程
in_char = raw_input("Enter to continue, Q to quit: ")ip
if in_char.upper() == 'Q':
break
print x * x
if __name__ == '__main__':
fn = sys.stdin.fileno()
arg = 5
p = Process(target = intask, args = (arg, fn))
p.start()
p.join()