您的位置: 网站首页> python并发编程> 当前文章
多进程修改全局变量及进程池Pool一些坑
老董-我爱我家房产SEO2020-03-14176围观,150赞
进程是系统进行资源分配和调度的一个独立单位,每个进程的内存单元是独立的,多进程中,每个进程中所有数据(包括全局变量)都各有拥有一份,互不影响。所以代码层面你定义一个全局变量,每个进程一开始可以使用但并不共享,进程内部会有自己的一份!
# ‐*‐ coding: utf‐8 ‐*‐ from multiprocessing import Process num_global = 10 def worker1(num): global num_global for i in range(num): num_global += 1 print("我是worker1进程,我的结果是{0}".format(num_global)) def worker2(num): global num_global for i in range(num): num_global += 1 print("我是worker2进程,我的结果是{0}".format(num_global)) if __name__ == "__main__": p1 = Process(target=worker1,args=(3,)) p2 = Process(target=worker2,args=(4,)) p1.start() p2.start() p1.join() p2.join() print("我还是我",num_global)
D:installpython3python.exe D:/pyscript/test/test2.py 我是worker1进程,我的结果是13 我是worker2进程,我的结果是14 我还是我 10 Process finished with exit code 0
如果在一个类里面用进程池会是什么效果?你会发现类里面的进程代码没有运行。如下代码大家自行研究!
# -*- coding: utf-8 -*- from multiprocessing import Pool global_name = "老王" class MyClass(object): def my_func(self): p_pool = Pool(5) for i in range(3): p_pool.apply_async(func=self.my_task, args=(i,)) p_pool.close() p_pool.join() def my_task(i): print(i, global_name) class MyClass2(object): def my_func(self): p_pool = Pool(5) for i in range(3): p_pool.apply_async(func=my_task, args=(i,)) p_pool.close() p_pool.join() # 这个函数是类外面的 def my_task(i): print(i, global_name) if __name__ == "__main__": obj = MyClass() obj.my_func() # 没有任何输出 print("以下是MyClass2类") obj2 = MyClass2() obj2.my_func()
D:python3installpython.exe D:/python/py3script/python66.py 以下是MyClass2类 0 老王 1 老王 2 老王 Process finished with exit code 0
很赞哦!
python编程网提示:转载请注明来源www.python66.com。
有宝贵意见可添加站长微信(底部),获取技术资料请到公众号(底部)。同行交流请加群
上一篇:通过进程池Pool的方式创建进程
下一篇:进程间的通信Queue队列
相关文章
文章评论
-
多进程修改全局变量及进程池Pool一些坑文章写得不错,值得赞赏
站点信息
- 网站程序:Laravel
- 客服微信:a772483200