python 线程锁 Lock 和 Condition

本文介绍了如何使用Python的threading模块、Lock和Condition类实现多线程任务执行,以及使用自定义的SafeQueue类进行生产者消费者模型的应用,展示了如何管理和同步多个线程的通信。
摘要由CSDN通过智能技术生成
from threading import Thread,Lock,Condition

task_lock = Lock()

def task(name: str):
    global task_lock
    for n in range(2):
        task_lock.acquire()
        print(f"{name}-round-{n}--step1\n",end='')
        print(f"{name}-round-{n}--step2\n",end='')
        print(f"{name}-round-{n}--step3\n",end='')
        task_lock.release()

t1 = Thread(target=task,args=("A",))
t2 = Thread(target=task,args=("B",))
t3 = Thread(target=task,args=("C",))

t1.start()
t2.start()
t3.start()

class SafeQueue:

    def __init__(self,size: int):
        self.size = size
        self.queue = list()
        self.__queue_lock = Condition()

    def put(self,item):
        self.__queue_lock.acquire()
        while len(self.queue) >= self.size:
            self.__queue_lock.wait()
        self.queue.insert(0,item)
        self.__queue_lock.notify_all()
        self.__queue_lock.release()


    def get(self):
        self.__queue_lock.acquire()
        while len(self.queue) == 0:
            self.__queue_lock.wait()
        result = self.queue.pop()
        self.__queue_lock.notify_all()
        self.__queue_lock.release()
        return result


class MsgProducer(Thread):
    def __init__(self,name: str,count: int,queue: SafeQueue):
        super().__init__()

        self.setName(name)
        self.count = count
        self.queue = queue

    def run(self) -> None:
        for n in range(self.count):
            msg = f"{self.getName()}--{n}"
            self.queue.put(msg)

class MsgConsumer(Thread):
    def __init__(self,name: str,queue: SafeQueue):
        super().__init__()

        self.setName(name)
        self.queue = queue
        self.daemon = True

    def run(self) -> None:
        while True:
            msg = self.queue.get()
            print(f"{self.getName()}--{msg}\n",end="")

queue = SafeQueue(3)
threads = list()
threads.append(MsgProducer("PA",10,queue))
threads.append(MsgProducer("PB",10,queue))
threads.append(MsgProducer("PC",10,queue))

threads.append(MsgConsumer("CA",queue))
threads.append(MsgConsumer("CB",queue))

for t in threads:
    t.start()

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值