Python 进程间共享变量(多进程通信安全)

import multiprocessing
import time


def worker(d, key, value):
    d[key] = value


if __name__ == '__main__':
    mgr = multiprocessing.Manager()
    d = mgr.dict()
    jobs = [multiprocessing.Process(target=worker, args=(d, i, i * 2)) for i in range(10) ]
    for j in jobs:
        j.start()
    for j in jobs:
        j.join()
    print('Results:')
    print(dict(d))

[打印结果]:Results: {1: 2, 6: 12, 3: 6, 0: 0, 2: 4, 4: 8, 5: 10, 7: 14, 8: 16, 9: 18}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Python 中,进程通信(IPC)可以使用多种方法来实现,包括共享内存、消息队列、管道、套接字等。这些方法都可以用来在进程传递数据或共享变量。 其中,共享内存是一种常用的方法,可以让多个进程共享同一块内存区域。在 Python 中,可以使用 multiprocessing 模块中的 Value 和 Array 类来实现进程共享变量。以下是一个示例: ```python import multiprocessing # 创建一个共享变量 shared_value = multiprocessing.Value('i', 0) # 定义一个函数,用于修改共享变量 def modify_shared_value(value): for i in range(10): with value.get_lock(): value.value += 1 print("Process {}: Shared value = {}".format(multiprocessing.current_process().name, value.value)) # 创建两个进程并启动它们 process1 = multiprocessing.Process(target=modify_shared_value, args=(shared_value,)) process2 = multiprocessing.Process(target=modify_shared_value, args=(shared_value,)) process1.start() process2.start() # 等待进程完成 process1.join() process2.join() # 输出最终的共享变量值 print("Final shared value = ", shared_value.value) ``` 在上面的示例中,我们首先使用 Value 类创建了一个整数类型的共享变量 shared_value,并初始化为 0。然后,我们定义了一个函数 modify_shared_value,该函数使用 with 语句获取共享变量的锁,并对其进行加 1 操作。最后,我们创建两个进程并启动它们,等待它们完成后输出最终的共享变量值。 需要注意的是,在共享变量的操作中,必须使用 with 语句获取共享变量的锁,以避免多个进程同时修改同一变量的问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值