栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

python3线程中锁机制的介绍及使用

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

如果还没弄懂锁机制是怎么使用的,那就用大家所说的,好记性不如烂笔头,直接套用代码到软件里运行起来吧~

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/12019.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号