扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
这篇文章给大家分享的是有关python3线程中锁机制的使用方法的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。
创新互联建站专注于企业全网营销推广、网站重做改版、曲麻莱网站定制设计、自适应品牌网站建设、HTML5、电子商务商城网站建设、集团公司官网建设、外贸营销网站建设、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为曲麻莱等各大城市提供网站开发制作服务。关于两个进程使用同步机制对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线程中锁机制的使用方法就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到吧!
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流