Python_RuntimeError

以下代码会报错


 - from multiprocessing import Pool import os, time, random
   
   
   def worker(msg):
       t_start = time.time()
   
       print("%s 开始执行,进程号为%d" % (msg, os.getpid()))
       # random.random()随机生成0~1 之间的浮点数
       time.sleep(random.random()*2)
       t_stop = time.time()
       print(msg, "执行完毕,耗时%0.2f" % (t_stop-t_start))
   
   
   # 定义一个进程池,最大进程数3 po = Pool(3)
   
   for i in range(0, 10):    po.apply_async(worker, (i,))
   
   
   print("----start----") po.close()  # 关闭进程池,关闭后po 不再接收新的请求 po.join() 
   # 等待po中所有子进程执行完成,必须放在close 语句之后 print("-----end------")

报的错误:

 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.

这段代码粘的mac、linux上没有问题,但是放到window上会报错
解决办法:

from multiprocessing import Pool
import os, time, random


def worker(msg):
    t_start = time.time()

    print("%s 开始执行,进程号为%d" % (msg, os.getpid()))
    # random.random()随机生成0~1 之间的浮点数
    time.sleep(random.random()*2)
    t_stop = time.time()
    print(msg, "执行完毕,耗时%0.2f" % (t_stop-t_start))


def main():
    # 定义一个进程池,最大进程数3
    po = Pool(3)

    for i in range(0, 10):
        po.apply_async(worker, (i,))

    print("----start----")
    po.close()  # 关闭进程池,关闭后po 不再接收新的请求
    po.join()  # 等待po中所有子进程执行完成,必须放在close 语句之后
    print("-----end------")


if __name__ == '__main__':
    main()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值