鱼C论坛

 找回密码
 立即注册
查看: 1151|回复: 3

[已解决]关于进程池Pool的问题

[复制链接]
发表于 2020-2-28 21:48:26 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
from multiprocessing import Pool


def worker(msg):
    print(msg)


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


print('----start----')
po.close()
po.join()
print('----end-----')


这个代码怎么怎么运行都没有结果,不会结束啊...
最佳答案
2020-2-29 11:15:22
本帖最后由 tjuwlb 于 2020-2-29 11:16 编辑

原因:多进程需要在main函数中运行

解决方法:加main函数,在main中调用
from multiprocessing import Pool


def worker(msg):
    print(msg)


def main():
    po = Pool(10)
    for i in range(0, 10):
        po.apply_async(worker, (i,))
    print('----start----')
    po.close()
    po.join()
    print('----end-----')


if __name__ == "__main__":
    main()
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-2-28 21:52:16 | 显示全部楼层
这样试试:
from multiprocessing import Pool


def worker(msg):
    print(msg)


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


print('----start----')
po.close()
print('----end-----')
po.join()
如果有帮助,请设最佳答案
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-2-29 11:15:22 | 显示全部楼层    本楼为最佳答案   
本帖最后由 tjuwlb 于 2020-2-29 11:16 编辑

原因:多进程需要在main函数中运行

解决方法:加main函数,在main中调用
from multiprocessing import Pool


def worker(msg):
    print(msg)


def main():
    po = Pool(10)
    for i in range(0, 10):
        po.apply_async(worker, (i,))
    print('----start----')
    po.close()
    po.join()
    print('----end-----')


if __name__ == "__main__":
    main()
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-2-29 13:07:27 | 显示全部楼层
tjuwlb 发表于 2020-2-29 11:15
原因:多进程需要在main函数中运行

解决方法:加main函数,在main中调用

大佬厉害..
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-6-12 22:45

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表