• Python 多进程报错问题


    Python 多进程报错问题

    windows环境下代码如下

    import multiprocessing
    import os
    import time
    
    def show_info(name, age):
        print(name, age)
    
        # 以元组方式传参
    sub_process = multiprocessing.Process(target=show_info, args=("李四", 20))
    sub_process.start()
    # 以字典方式传参
    sub2_process = multiprocessing.Process(target=show_info, kwargs={"name": "张三", "age": 40})
    sub2_process.start()
    # 以两种方式传参
    sub3_process = multiprocessing.Process(target=show_info, args=("王五",), kwargs={"age": 60})
    sub3_process.start()

    运行会报如下错误

    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.
    

      加上 if __name__ == '__main__'   后,错误消失

    import multiprocessing
    def show_info(name, age):
        print(name, age)
    if __name__ == '__main__':
        # 以元组方式传参
        sub_process = multiprocessing.Process(target=show_info, args=("李四", 20))
        sub_process.start()
        # 以字典方式传参
        sub2_process = multiprocessing.Process(target=show_info, kwargs={"name": "张三", "age": 40})
        sub2_process.start()
        # 以两种方式传参
        sub3_process = multiprocessing.Process(target=show_info, args=("王五",), kwargs={"age": 60})
        sub3_process.start()

    但是在linux和mac环境下,不加 if __name__ == '__main__'   是可以正常运行的,这是为什么呢?

    请你们自己去思考哦。

    小细节:windows创建多进程,会默认把当前文件全部代码copy一份,放在其他创建出来的进程里面去执行,就形成了无限递归。

    而且进程之前不共享全局变量。每个进程里面都有自己的一份儿全局变量

  • 相关阅读:
    java主函数的含义
    this关键字简单应用
    如何将util.Date转化为sql.Date
    利用JavaScript来实现省份—市县的二级联动
    通过Ajax异步提交的方法实现从数据库获取省份和城市信息实现二级联动(xml方法)
    折半查找(java)(边学习边更新)
    第五章 上
    Jframe关闭窗口时的事件
    C#退出程序自动重新启动
    Extjs4.0 开发笔记与Easyui的整合
  • 原文地址:https://www.cnblogs.com/yigongzi/p/14273412.html
Copyright © 2020-2023  润新知