python运行子进程时报错:The “freeze_support()“ line can be omitted if the program is not going to be froze
问题描述:执行子进程时程序会报错代码如下:import multiprocessingimport timedef 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 = mul
·
问题描述:
执行子进程时程序会报错
代码如下:
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()
魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐


所有评论(0)