Python中文
首页
教程
问答
标签
搜索
登录
注册
python多处理.Process.Manager没有产生一致的结果?
回答此问题可获得
20
贡献值,回答如果被采纳可获得
50
分。
<p>我写了下面的代码来说明我所看到的问题。我试图使用<code>Process.Manager.list()</code>来跟踪一个列表并增加该列表的随机索引。在</p> <p>每次生成100个进程,每个进程将列表的随机索引递增1。因此,人们期望每次得到的列表的总和都是相同的,对吗?我得到了203到205之间的数据。在</p> <pre><code>from multiprocessing import Process, Manager import random class MyProc(Process): def __init__(self, A): Process.__init__(self) self.A = A def run(self): i = random.randint(0, len(self.A)-1) self.A[i] = self.A[i] + 1 if __name__ == '__main__': procs = [] M = Manager() a = M.list(range(15)) print('A: {0}'.format(a)) print('sum(A) = {0}'.format(sum(a))) for i in range(100): procs.append(MyProc(a)) map(lambda x: x.start(), procs) map(lambda x: x.join(), procs) print('A: {0}'.format(a)) print('sum(A) = {0}'.format(sum(a))) </code></pre>
0 条评论
分类:
Python问答
请先
登录
后评论
默认排序
时间排序
1 个回答
匿名
1天前
擅长:python、mysql、java
<p>通过上面的评论得到了答案,有一个竞速条件发生,因为下面这条线:</p> <pre><code>self.A[i] = self.A[i] + 1 </code></pre> <p>实际上是两个操作,一个<code>__getitem__</code>和一个<code>__setitem__</code></p>
请先
登录
后评论
针对此问题:
更多的回答
关注
89
关注
收藏
1
收藏,
216
浏览
网友 提问于 2天前
相关Python问题
如何在python中从数据帧列中删除分类值?
5 回答
如何在python中从数据帧列表中删除引号
8 回答
如何在python中从数据帧创建列表
5 回答
如何在Python中从数据帧创建嵌套的JSON
7 回答
如何在Python中从数据帧显示wordcloud
10 回答
如何在Python中从数据帧的时间戳中删除字符
4 回答
如何在Python中从数据帧绘制简单绘图?
6 回答
如何在python中从数据帧行提取具有特定长度的范围?
9 回答
如何在python中从数据帧设置dict中的值
7 回答
如何在Python中从数据库中获得一个结果
10 回答
如何在python中从数据框中绘制分类条形图
9 回答
如何在Python中从数据框中选择特定细节?
6 回答
如何在python中从数据集中删除unicode
4 回答
如何在python中从数据集中删除某些数值?
8 回答
如何在python中从数据集中选择行
10 回答
如何在Python中从数组中删除元素
1 回答
如何在python中从数组中删除单个倒逗号?
6 回答
如何在python中从数组中删除对象?
2 回答
如何在python中从数组中删除引号
1 回答
如何在python中从数组中删除所有最小值
10 回答