全国旗舰校区

不同学习城市 同样授课品质

北京

深圳

上海

广州

郑州

大连

武汉

成都

西安

杭州

青岛

重庆

长沙

哈尔滨

南京

太原

沈阳

合肥

贵阳

济南

下一个校区
就在你家门口
+
当前位置:首页  >  技术干货  >  详情

python使用互斥锁处理资源分配

来源:千锋教育
发布人:xqq
2023-11-11

推荐

在线提问>>

python使用互斥锁处理资源分配

1、threading模块中定义了Lock类,可以实现锁

创建锁对象:mutex=threading.Lock()

上锁:mutex.acquire()

释放锁:mutex.release()

2、注意

如果这个锁之前是没有上锁的,那么acquire就不会阻塞

如果调用acquire之前这个锁是被其它线程上了锁的,那么acquire就会阻塞,直到这个锁被释放

3、实例

importthreading

importtime

num=0

defcount_test1():

globalnum

foriinrange(100000):

mutex.acquire()

num+=1

mutex.release()

print("count_test1-->num:%s"%num)

defcount_test2():

globalnum

foriinrange(100000):

mutex.acquire()

num+=1

mutex.release()

print("count_test2-->num:%s"%num)

mutex=threading.Lock()

t1=threading.Thread(target=count_test1)

t2=threading.Thread(target=count_test2)

t1.start()

t2.start()

t1.join()

t2.join()

print("最终的num:%s"%num)

以上就是python使用互斥锁处理资源分配,希望能对大家有所帮助,更多Python学习教程请关注IT培训机构:千锋教育。

相关文章

python如何配置Logging处理器

pythonos模块有几种用法?

python如何定制日志输出格式

python析构器是什么意思?

python列表的优点探究

开班信息 更多>>

课程名称
全部学科
咨询

HTML5大前端

Java分布式开发

Python数据分析

Linux运维+云计算

全栈软件测试

大数据+数据智能

智能物联网+嵌入式

网络安全

全链路UI/UE设计

Unity游戏开发

新媒体短视频直播电商

影视剪辑包装

游戏原画

    在线咨询 免费试学 教程领取