问题描述:
执行子进程时程序会报错
代码如下:
import multiprocessing
import time
def dance():
for i in range(3):
print('跳舞中...')
time.sleep(0.2)
def sing():
for i in range(3):
print('唱歌中...')
time.sleep(0.2)
# 创建子进程
dance_process = multiprocessing.Process(target=dance)
sing_process = multiprocessing.Process(target=sing)
# 执行子进程
dance_process.start()
# 等待第一个子进程执行结束后执行第二个子进程
dance_process.join()
sing_process.start()
报错:
原因分析:
子进程实际上是对父进程变量、函数(方法)等的拷贝。对于linux和mac而言,创建子进程时,不会拷贝父进程的执行的代码,但是windows系统也会拷贝父进程执行的代码。所以在创建子进程时,拷贝了执行代码,其中包含了创建子进程的代码,如此递归,会无限制的创建子进程,进而报错。
解决方案:
将执行的程序放在主模块下,这样windows下,子进程不会拷贝主模块中的代码,防止陷入无限递归。
改进后的程序如下:
import multiprocessing
import time
def dance():
for i in range(3):
print('跳舞中...')
time.sleep(0.2)
def sing():
for i in range(3):
print('唱歌中...')
time.sleep(0.2)
# 主模块的作用
# 1、防止别人调用时执行(程序测试时使用)
# 2、防止子进程拷贝,陷入无限递归
if __name__ == '__main__':
# 创建子进程
dance_process = multiprocessing.Process(target=dance)
sing_process = multiprocessing.Process(target=sing)
# 执行子进程
dance_process.start()
# 等待第一个子进程执行结束后执行第二个子进程
dance_process.join()
sing_process.start()