本文实例为大家分享了python多进程共享变量的相关代码,供大家参考,具体内容如下
from multiprocessing import Process, Manager
import os
import time
class MulFun():
def __init__(self):
self.a = [1,2,3,4,5]
self.b = 0
self.c = {}
self.s = "hello world"
self.radius = Manager().dict()
self.radius['a'] = self.a
self.radius['b'] = self.b
self.radius['c'] = self.c
self.radius['s'] = self.s
def func1(self):
self.b = self.radius['b']
for i in range(10):
self.b += i
self.radius['b'] = self.b
time.sleep(0.5)
print '1: ', self.radius['b'],':', self.radius['c'], os.getpid()
def func2(self):
self.c = self.radius['c']
for i in ['ab', 'bc', 'cd', 'df', 'fg']:
self.c[i] = i + i
self.radius['c'] = self.c
time.sleep(0.5)
print '2: ', self.radius['b'],':', self.radius['c'], os.getpid()
def run(self):
process1 = Process(target=self.func1, args=())
process2 = Process(target=self.func2, args=())
process1.daemon = True
process2.daemon = True
process1.start()
process2.start()
process1.join()
process2.join()
class MulSun1:
def __init__(self, radius):
self.radius = radius
self.a = radius['a']
self.s = radius['s']
def process(self):
for i, j in enumerate(self.a):
#self.a[i] = j * 2
#self.radius['a'] = self.a
time.sleep(0.5)
print '1: ', self.radius['a'], ' & ', self.radius['s']
class MulSun2:
def __init__(self, radius):
self.radius = radius
self.a = radius['a']
self.s = radius['s']
def process(self):
for i in range(10):
self.s = self.s + ':% s' %i
if i < len(self.a):
self.a[i] += i
else:
self.a.append(i + i)
self.radius['s'] = self.s
self.radius['a'] = self.a
time.sleep(0.5)
print '2: ', self.radius['a'], ' & ', self.radius['s']
if __name__ == '__main__':
aa = MulFun()
s1 = MulSun1(aa.radius)
s2 = MulSun2(aa.radius)
process1 = Process(target=s1.process, args=())
process2 = Process(target=s2.process, args=())
process1.daemon = True
process2.daemon = True
process1.start()
process2.start()
process1.join()
process2.join()
print "------------------------"
print 'process id:', os.getpid()
print 'done'
print aa.radius['a'], ' & ', aa.radius['s']
以上就是本文的全部内容,希望对大家学习python程序设计有所帮助。
标签:
python,多进程,共享变量
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“python多进程共享变量”评论...
更新动态
2025年10月29日
2025年10月29日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]