2021-03-10

‘’’
互斥锁线程
‘’’
import threading
import time
g_num=0
def test1(num):
#global是全局变量
global g_num
for i in range(num):
mutex.acquire()#上锁
g_num +=1
mutex.release()#解锁
print("—test1—num=%d"%g_num)
def test2(num):
global g_num
for i in range(num):
mutex.acquire()#上锁
g_num += 1
mutex.release()#解锁
print("—test2—num=%d"%g_num)
#创建一个互斥锁,默认是未上锁的状态
mutex=threading.Lock()
#创建2个线程,让他们各自对num加1000000次
p1=threading.Thread(target=test1,args=(1000000,))
p1.start()
p2=threading.Thread(target=test2,args=(1000000,))
p2.start()
#等待计算完成
p1.join()
p2.join()
print(“2个线程对同一个全局变量操作之后的最终结果是:%s” %g_num)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值