python限制进程数_Python连载36-线程数量限制、Timer、可重入锁

一、允许一个资源最多由几个线程同时进行

命令行:threading.Semaphore(个数)

代表现在最多有几个线程可以进行操作

importthreadingimporttime#参数定义了最多几个线程可以使用资源

semaphore= threading.Semaphore(3)#这里就是指最多有三个线程可以进行操作

deffunc():ifsemaphore.acquire():for i in range(2):print(threading.current_thread().getName() + "get semapore")

time.sleep(5)

semaphore.release()print(threading.current_thread().getName() + "release semaphore")for i in range(8):

t1= threading.Thread(target=func,args=())

t1.start()

二、Timer讲解

格式:threading.Timer(时间间隔,函数)

代表这个函数在“时间间隔”的时间之后启动

deffunc2():print("I am running.....")

time.sleep(3)print("I an done.......")if __name__ == "__main__":

t2= threading.Timer(6,func2) #代表6秒之后开始启动线程func2

t2.start()

i=0whileTrue:print("{0}*********".format(i))

time.sleep(3)

i+= 1

三、可重入锁

1.一个锁可以被一个线程多次申请

2.主要解决递归调用的时候哦,需要申请锁的情况,可以防止被锁住,重新申请

classMyThread(threading.Thread):defrun(self):globalnum

time.sleep(1)if mutex.acquire(1):

num= num+1msg= self.name + "set num to"+str(num)print(msg)

mutex.acquire()

mutex.release()

mutex.release()deftest():for i in range(5):

t3=MyThread()

t3.start()if __name__ == "__main__":

num=0

mutex= threading.RLock()#可重入锁

test()

解释:我们的线程可以直接进行,不会因为一个申请了,就会被阻塞,依然还可以申请这把锁

四、源码

d25_4_Rlock.py

https://github.com/ruigege66/Python_learning/blob/master/d25_4_Rlock.py

2.CSDN:https://blog.csdn.net/weixin_44630050(心悦君兮君不知-睿)

3.博客园:https://www.cnblogs.com/ruigege0000/

4.欢迎关注微信公众号:傅里叶变换,后台回复”礼包“,获取大数据学习资料

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值