一个python多进程计数器的问题
问题描述
写了个多进程的脚本,然后其中有个计数器,大致逻辑如下
def worker(co): # working co[0] += 1 if co[0] % 10000 == 0:logging.info('Parsed {}'.format(co[0]))def main(): co = Manager.list() co[0] = 1 pool = Pool() for i in range(10):pool.apply_async(worker, (co,))
最终程序运行时发现个有趣的问题
INFO: 2017-04-11 16:42:19,288 - 13582 - Parsed 879999INFO: 2017-04-11 16:42:19,292 - 13583 - Parsed 880000INFO: 2017-04-11 16:42:19,295 - 13593 - Parsed 880001INFO: 2017-04-11 16:42:19,297 - 13597 - Parsed 880001
这里的880001,多一个我能理解,当if co[0] % 10000 == 0判断时,其他进程已经做了加一操作了,但这个879999少一个,我就有点想不通了?
问题解答
回答1:满足打印条件的进程刚要打印,其它进程在做+1操作,取值,+1,赋值回去需要好几条指令,其实可能出现任何值,因为取值这条指令可以发生在任何时刻。
相关文章:
1. javascript - webpack构建工具重构代码的流程是怎么样的?2. java - 安卓调用c++lib3. 如何解决docker宿主机无法访问容器中的服务?4. css3 - 求css页面解决方案5. mysql 5个left关键 然后再用搜索条件 几千条数据就会卡,如何解决呢6. HTML5表单必填属性设置自定义验证消息?7. javascript - 想做一个canvas的触摸画板,但屏幕会在画的时候滚来滚去,如何阻止?8. java - 大家可以分享一下各自如何高效编程吗?就是一些常用的配置及习惯等等9. css - 如何讓圖片像雲一樣的行為?10. mysql - sql 左连接结果union右连接结果,导致重复性计算怎么解决?

网公网安备