import time
from multiprocessing import Process
def processFunc(num,time1):
print num
time.sleep(time1)
if __name__ == '__main__':
child_proc1 = Process(target=processFunc, args=(1,2))
child_proc1.start()
child_proc1.join()
很简单的程序
如果不写if __name__ == '__main__': 就会产生无数进程 最终占据所有内存
原因:
__name__是指示当前py文件调用方式的方法。如果它等于"__main__"就表示是直接执行,如果不是,则用来被别的文件调用,这个时候if就为False,那么它就不会执行最外层的代码了。
这样的话,子进程一载入这个文件,就会调用 processFunc 函数,会执行生成子进程的代码,因为他是最外层代码,或者叫做全局代码,从而产生多个进程。
一点小经验分析