操作系统学习实战篇——实现支持异步任务的线程池

在这里插入图片描述在这里插入图片描述

Python同步原语

互斥锁

在每一次对临界资源进行读或写操作时,先加锁,操作完成之后再解锁。

Python互斥锁的使用:

lock = threading.Lock()  # 申请锁
lock.acquire()   # 加锁
lock.release()   # 解锁
条件变量

判断条件是否满足,一个线程在条件满足的时候执行;当条件不满足时睡眠,等待另一个线程满足条件将睡眠线程唤醒,使其继续执行下去。

Python条件变量的使用:

condition=threading.Condition()   # 申请条件变量
condition.acquire()               # 加锁
condition.release()               # 解锁
condition.wait()                  # 等待
condition.notify()                # 通知

实现线程安全的队列Queue

队列用于存放多个元素,是存放各种元素的“池”。

在这里插入图片描述
队列可能有多个线程同时操作,因此需要保证线程安全。两个线程安全的情况如下:

在这里插入图片描述queue.py

# -*- encoding = utf-8 -*-
import threading
import time


class ThreadSafeQueueException(Exception):
    pass


class ThreadSafeQueue(object):

    def __init__(self,max_size=0):
        self.queue = []
        self.max_size = max_size
        self.lock = threading.Lock()
        self.condition = threading.Condition()

    # 获取当前队列中元素的数量
    def size(self):
        self.lock.acquire()
        size = len(self.queue)
        self.lock.release()
        return size

    # 往队列中放入元素
    def push(self,item):
        if self.size() != 0 and self.size() > self.max_size:
            return ThreadSafeQueueException
        self.lock.acquire()
        self.queue.append(item)
        self.lock.release()
        # 如果当前队列的size为0,一个线程去获取size时就会阻塞。
        # 当我们往队列中放入元素时,size不为0了,就可以通知阻塞线程继续执行。
        self.condition.acquire()
        self.condition.notify()
        self.condition.release()

    # 往队列中批量放入元素
    def batch_push(self,item_list):
        if not isinstance(item_list,list):
            item_list = list(item_list)
        for item in item_list:
            self.push(item)

    # 从队列中取出元素
    def pop(self, block=False, timeout=0):
        if self.size() == 0:
            # 需要阻塞等待
            if block:
                self.condition.acquire()
                self.condition.wait(timeout=timeout)
                self.condition
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值