python多线程通信方式

锁机制

1. Lock() 同步锁(互斥锁)

构造方法:

lock = threading.Lock()

方法:

  • acquire(block=True, timeout=None): 获取锁,可选参数blockTrue时,如果锁被占用则阻塞等待;timeout为等待的最大时间。
  • release(): 释放锁。

2. RLock() 递归锁

构造方法:

rlock = threading.RLock()

方法:

  • acquire(block=True): 获取锁,可被同一个线程多次获取。
  • release(): 释放锁,必须与acquire()调用次数匹配。

3. Condition() 条件锁

构造方法:

condition = threading.Condition()

方法:

  • acquire(): 上锁。
  • release(): 解锁。
  • wait(timeout=None): 使线程等待直到被唤醒或超时。
  • notify(n=1): 唤醒等待中的一个线程。
  • notify_all(): 唤醒所有等待中的线程。

4. Event() 事件锁

构造方法:

event = threading.Event()

方法:

  • set(): 设置事件状态为True
  • clear(): 清除事件状态,将其设置为False
  • is_set(): 判断锁状态
  • wait(timeout=None): 阻塞线程直到事件状态为True

5. Semaphore() 信号量锁

构造方法:

semaphore = threading.Semaphore(value)

方法:

  • acquire(block=True, timeout=None): 获取信号量,如果信号量等于0,则阻塞线程,知道信号量大于0时唤醒,将计数减1并恢复线程
  • release(): 释放信号量,信号量计数加1,使阻塞的线程有机会唤醒。

信号量代表的就是资源的数量,最低只能为0


Queue(队列)

Queue(maxsize=0)

  • 创建队列: 初始化一个新的队列实例,maxsize参数定义队列的最大长度。如果未设置或设置为0,队列长度无限制。

put(item, block=True, timeout=None)

  • 添加任务到队列: 将一个元素放入队列中。如果可选的block参数为True(默认值),在队列满时,操作将阻塞,直到有空位。timeout参数指定阻塞的最长时间。

get(block=T

评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

星眺北海

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值