您的位置: 网站首页> python并发编程> 当前文章
多进程修改全局变量及进程池Pool一些坑
老董-我爱我家房产SEO2020-03-14162围观,147赞
进程是系统进行资源分配和调度的一个独立单位,每个进程的内存单元是独立的,多进程中,每个进程中所有数据(包括全局变量)都各有拥有一份,互不影响。所以代码层面你定义一个全局变量,每个进程一开始可以使用但并不共享,进程内部会有自己的一份!
# ‐*‐ 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一些坑文章写得不错,值得赞赏


