您好,登录后才能下订单哦!
密码登录
登录注册
点击 登录注册 即表示同意《亿速云用户服务条款》
这篇文章给大家分享的是有关python3线程中锁机制的使用方法的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。
关于两个进程使用同步机制对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
感谢各位的阅读!关于python3线程中锁机制的使用方法就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到吧!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。