Python多进程 AttributeError: Can't get attribute 'worker' on module '__main__' from

将创建进程池对象放在子进程函数之前会产生

AttributeError: Can't get attribute 'worker' on <module '__main__' from '/home/tian/file/pool.py'>
from multiprocessing import Pool
from time import sleep,ctime

#创建进程池对象
pool = Pool()

def worker(msg):
    sleep(2)
    print(msg)
    return msg


result = []
#向进程池添加事件
for i in range(10):
    msg = 'hello %d'%i
    r = pool.apply_async(func=worker,args=(msg,))
    result.append(r)

#关闭进程池
pool.close()
#回收进程池
pool.join()
print('=================')
for i in result:
    print(i.get())

放在子进程函数之后就不会产生这样的错误

from multiprocessing import Pool
from time import sleep,ctime

def worker(msg):
    sleep(2)
    print(msg)
    return msg
#创建进程池对象
pool = Pool()

result = []
#向进程池添加事件
for i in range(10):
    msg = 'hello %d'%i
    r = pool.apply_async(func=worker,args=(msg,))
    result.append(r)

#关闭进程池
pool.close()
#回收进程池
pool.join()
print('=================')
for i in result:
    print(i.get())

 

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Reckess

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值