鱼C论坛

 找回密码
 立即注册
查看: 2079|回复: 7

[已解决]多进程问题求助~~

[复制链接]
发表于 2020-3-10 18:07:52 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 Python3005 于 2020-3-10 18:09 编辑
  1. import multiprocessing as mp
  2. import time

  3. def test(num, value):
  4.     time.sleep(1)
  5.     value.value += num
  6.     print(value.value)

  7. def multip():
  8.     value =mp.Value('i')
  9.     pool = mp.Pool()
  10.     for each in range(32):
  11.         pool.apply_async(func = test, args =(each, value))
  12.     pool.close()
  13.     pool.join()
  14.     return value.value
复制代码


请问1:为何print命令不起作用?
2:value.value最后返回的是0,为何没有叠加?
最佳答案
2020-3-10 20:08:20
进程池内存共享数据使用 Manager吧。

  1. from multiprocessing import Pool,Manager

  2. def Func1(a):
  3.     a.value += 1
  4.     print(a.value)


  5. if __name__ == '__main__':
  6.     manager = Manager()
  7.     num = manager.Value('i', 1)
  8.     pool = Pool()
  9.     for each in range(32):
  10.         pool.apply_async(func = Func1, args =(num,))
  11.     pool.close()
  12.     pool.join()

  13.     print (num.value)
  14.     input()

复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-3-10 18:50:01 | 显示全部楼层
您写了这些函数没有去调用......
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-10 19:11:46 | 显示全部楼层
lixiangyv 发表于 2020-3-10 18:50
您写了这些函数没有去调用......

调用这个multip()
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-10 19:24:45 | 显示全部楼层
value =mp.Value('i') #全局的,不用传参,传参进不行

多进程一定要使用
if __name__== "__main__":

直接点击运行.py文件才能看到结果。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-10 19:30:18 | 显示全部楼层
楼上说的没问题,但是这个程序就算加上了楼上说的也不会有结果,你这里不应该使用 Pool,而应该使用 Proces。
在官方文档里,多进程 共享内存 是使用 Process 来实现的。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-10 20:08:20 | 显示全部楼层    本楼为最佳答案   
进程池内存共享数据使用 Manager吧。

  1. from multiprocessing import Pool,Manager

  2. def Func1(a):
  3.     a.value += 1
  4.     print(a.value)


  5. if __name__ == '__main__':
  6.     manager = Manager()
  7.     num = manager.Value('i', 1)
  8.     pool = Pool()
  9.     for each in range(32):
  10.         pool.apply_async(func = Func1, args =(num,))
  11.     pool.close()
  12.     pool.join()

  13.     print (num.value)
  14.     input()

复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-11 00:30:12 | 显示全部楼层
ba21 发表于 2020-3-10 20:08
进程池内存共享数据使用 Manager吧。

多谢大佬!还想请问Manager.Value 和multiprocessing.Value 有啥区别?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-11 19:02:37 | 显示全部楼层
Python3005 发表于 2020-3-11 00:30
多谢大佬!还想请问Manager.Value 和multiprocessing.Value 有啥区别?

从文档来看multiprocessing.Value是一个主进程传进进程2,等进程2出来;再才能再给进程3 .....
Manager.Value多进程同时共享。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-7-6 22:57

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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