
如果大家不清楚锁机制的话,那就一定要好好看下这篇文章,下面就是针对锁机制给大家详细介绍下怎么去使用以及基本的内容介绍,不同于大家在课堂上学习的知识,下面内容,主要将重点知识给大家做下讲解哦~具体内容一起来看下吧~
关于两个进程使用同步机制对Value对象修改:
主进程加100000次;子进程减100000次;
代码如下:
import multiprocessing
from multiprocessing import Queue
from multiprocessing import Value, Array
g_value = Value('i', 0)
#对g_value处理封装成函数
def deal(gvalue, val):
gvalue.acquire()
gvalue.value += val
gvalue.release()
#进程函数, 共享内存必须通过参数传入
def func(gvalue):
i = 0
while i < 100000:
#加1
deal(gvalue, 1)
i += 1
if __name__ == "__main__":
print("g_value init value:", g_value.value)
#全局消息队列
main_msgq = Queue()
#消息队列必须通过参数传入到子进程,否则无效
p = multiprocessing.Process(target=func, args=(g_value,))
p.start()
i = 0
while i < 100000:
#减1
deal(g_value, -1)
i += 1
p.join()
print("g_value end value:", g_value.value)
结果:符合预期,最后g_value的值为0;
g_value init value: 0 g_value end value: 0
如果还没弄懂锁机制是怎么使用的,那就用大家所说的,好记性不如烂笔头,直接套用代码到软件里运行起来吧~
神龙|纯净稳定代理IP免费测试>>>>>>>>天启|企业级代理IP免费测试>>>>>>>>IPIPGO|全球住宅代理IP免费测试



