鱼C论坛

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

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

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

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

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

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

def test(num, value):
    time.sleep(1)
    value.value += num
    print(value.value)

def multip():
    value =mp.Value('i')
    pool = mp.Pool()
    for each in range(32):
        pool.apply_async(func = test, args =(each, value))
    pool.close()
    pool.join()
    return value.value

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

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


if __name__ == '__main__':
    manager = Manager()
    num = manager.Value('i', 1) 
    pool = Pool()
    for each in range(32):
        pool.apply_async(func = Func1, args =(num,))
    pool.close()
    pool.join()

    print (num.value)
    input()
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-3-10 18:50:01 | 显示全部楼层
您写了这些函数没有去调用......
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

调用这个multip()
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

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

直接点击运行.py文件才能看到结果。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

使用道具 举报

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

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


if __name__ == '__main__':
    manager = Manager()
    num = manager.Value('i', 1) 
    pool = Pool()
    for each in range(32):
        pool.apply_async(func = Func1, args =(num,))
    pool.close()
    pool.join()

    print (num.value)
    input()
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

多谢大佬!还想请问Manager.Value 和multiprocessing.Value 有啥区别?
想知道小甲鱼最近在做啥?请访问 -> 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多进程同时共享。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-24 17:59

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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