python 主线程sleep 子线程,python多线程之线程锁二(同一时间一个线程获得2把线程锁)...

#coding:utf-8

'''线程锁'''

import threading

import time

num = 0 #全局变量

num2 = 0

def runs():

time.sleep(1)

global num #在函数内部要对全局变量进行更改,需要进行声明

global num2

lock.acquire() #在操作时锁住,防止其他线程在同一时间对num变量进行加1,从而确保数据在同一时间确保只有一个线程对它进行更改,不然造成数据不正确

num += 1

lock.acquire() #再获得一把锁

num2 += 2

#在这里一个线程获得了2把锁,所以需要释放2次

lock.release()  # 释放第1把锁,加1完之后释放锁,只有释放之后下一个线程才会开始对num进程操作,不释放的话否则会被该线程一直占用,导致程序不能继续执行下去,一直处于阻塞状态

time.sleep(0.01)

lock.release() # 释放第2把锁,加完2后释放锁

time.sleep(0.01)

print("%s" % num)

lock = threading.RLock() #RLock是允许同时获得好几把锁增加一把锁,如果只需一把锁,那么用threading.Lock()就可以

#启动一百个线程,也就是说这100个线程同时运行rusn函数

for i in range(500):

t = threading.Thread(target=runs,)

t.start()

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值