这篇文章给大家分享的是有关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线程中锁机制的使用方法就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到吧!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
原文链接:https://www.py.cn/jishu/jichu/20964.html