欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-04-14 23:33:05
一、允许一个资源最多由几个线程同时进行 命令行:threading.Semaphore(个数) 代表现在最多有几个线程可以进行操作 二、Timer讲解 格式:threading.Timer(时间间隔,函数) 代表这个函数在“时间间隔”的时间之后启动 三、可重入锁 1.一个锁可以被一个线程多次申请 2 ......

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

命令行:threading.semaphore(个数)

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

 

import threading

import time

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

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

def func():

    if semaphore.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()

 

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

二、timer讲解

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

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

 

def func2():

    print("i am running.....")

    time.sleep(3)

    print("i an done.......")

if __name__ == "__main__":

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

    t2.start()

    i = 0

    while true:

        print("{0}*********".format(i))

        time.sleep(3)

        i += 1

 

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

三、可重入锁

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

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

 

class mythread(threading.thread):

    def run(self):

        global num

        time.sleep(1)

        if mutex.acquire(1):

            num = num+1

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

            print(msg)

            mutex.acquire()

            mutex.release()

            mutex.release()

def test():

    for i in range(5):

        t3 = mythread()

        t3.start()

 

if __name__ == "__main__":

    num = 0

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

    test()

 

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

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

 

四、源码

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.欢迎关注微信公众号:傅里叶变换,后台回复”礼包“,获取大数据学习资料

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