【报错解决】RuntimeError: An attempt has been made to start a new process...

【报错解决】RuntimeError: An attempt has been made to start a new process…

今天来记录一个Pycharm当中的报错解决:

复制代码
RuntimeError: 
        An attempt has been made to start a new process before the
        current process has finished its bootstrapping phase.
 
        This probably means that you are not using fork to start your
        child processes and you have forgotten to use the proper idiom
        in the main module:
 
            if __name__ == '__main__':
                freeze_support()
                ...
 
        The "freeze_support()" line can be omitted if the program
        is not going to be frozen to produce an executable.
复制代码

传统方案
经过查阅资料,发现上面错误对应的报错原因是,这是因为通常情况下,在linux系统中可以使用多个子进程加载数据,而在windows系统中不能。

在windows系统中需要将进程数设置为单进程,所以我们需要将数据处理部分DataLoader中的参数 num_workers设置为0或者采用默认为0的设置,即可解决此报错问题。
这种方式的缺陷是改为采用单进程加载,速度会变慢。

方案二

代码在运行 epoch 之前,加上 if __name__=='__main__'

 

方案三

那么,若项目程序中不含Dataloader相关函数,且方法二不可行,还有其他解决方式嘛?
答案是有的。加main函数,在main中调用,继续多进程加载,可以加速。
参考链接5
在将main.py中的主程序用def main()囊括起来,最后添加上两行

if __name__ == '__main__':
    main()

即可成功解决此报错。

posted @   咖啡陪你  阅读(1779)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
· spring官宣接入deepseek,真的太香了~
历史上的今天:
2021-12-13 支持向量回归机(SVR)代码
2021-12-13 sklearn中SVC和SVR的参数说明
点击右上角即可分享
微信分享提示