Python提供的Condition对象提供了对复杂线程同步问题的支持。Condition被称为条件变量,除了提供与Lock类似的acquire和release方法外,还提供了wait和notify方法。

使用Condition的主要方式为:线程首先acquire一个条件变量,然后判断一些条件。如果条件不满足则wait;如果条件满足,进行一些处理改变条件后,通过notify方法通知其他线程,其他处于wait状态的线程接到通知后会重新判断条件。不断的重复这一过程,从而解决复杂的同步问题。

下面我们通过很著名的“生产者-消费者”模型来来演示下,在Python中使用Condition实现复杂同步

import threading
import time condition = threading.Condition()
products = 0 class Producer(threading.Thread):
def __init__(self):
threading.Thread.__init__(self) def run(self):
global condition, products
while True:
if condition.acquire():
if products < 10:
products += 1;
print "Producer(%s):deliver one, now products:%s" %(self.name, products)
condition.notify()
else:
print "Producer(%s):already 10, stop deliver, now products:%s" %(self.name, products)
condition.wait();
condition.release()
time.sleep(2) class Consumer(threading.Thread):
def __init__(self):
threading.Thread.__init__(self) def run(self):
global condition, products
while True:
if condition.acquire():
if products > 1:
products -= 1
print "Consumer(%s):consume one, now products:%s" %(self.name, products)
condition.notify()
else:
print "Consumer(%s):only 1, stop consume, products:%s" %(self.name, products)
condition.wait();
condition.release()
time.sleep(2) if __name__ == "__main__":
for p in range(0, 2):
p = Producer()
p.start() for c in range(0, 10):
c = Consumer()
c.start()

另外:Condition对象的构造函数可以接受一个Lock/RLock对象作为参数,如果没有指定,则Condition对象会在内部自行创建一个RLock;除了notify方法外,Condition对象还提供了notifyAll方法,可以通知waiting池中的所有线程尝试acquire内部锁。由于上述机制,处于waiting状态的线程只能通过notify方法唤醒,所以notifyAll的作用在于防止有线程永远处于沉默状态。

最新文章

  1. showSetPwdDialog--自定义对话框
  2. python学习笔记-python程序运行
  3. 【jmeter】接口稳定性测试
  4. c#实现万年历示例分享 万年历农历查询
  5. [CLR via C#]18. Attribute
  6. js数组的操作及数组与字符串的相互转化
  7. CCNA CCNP CCIE所有实验名称完整版
  8. Apache Mina(二)
  9. Elasticsearch搜索之most_fields分析
  10. 转: 【Java并发编程】之三:线程挂起、恢复与终止的正确方法(含代码)
  11. js Date() 浏览器兼容问题解决
  12. A 洛谷 P3601 签到题 [欧拉函数 质因子分解]
  13. Quartz.NET快速入门指南
  14. tomcat 启动报错org.hibernate.cfg.annotations.SimpleValueBinder.setType
  15. 【转】如何快速识别应用MOS管,几张图片就搞定了
  16. 如何解决input file 选取相同文件后,change事件不起作用解决方法
  17. (原)ubuntu中安装kate
  18. 让你分分钟了解Web接口测试
  19. 读/写锁的实现和应用(高并发状态下的map实现)
  20. Kafka消息系统基础知识索引

热门文章

  1. GPIO相关寄存器描述和怎么配置
  2. bash小结
  3. Python3 Selenium自动化web测试 ==&gt;FAQ:日期格式和日期字符串格式相互转换
  4. 《剑指offer》树专题 (牛客10.25)
  5. 最新 猎豹移动java校招面经 (含整理过的面试题大全)
  6. 同一个ip,不同端口号,cookie会被覆盖
  7. 通过JS动态追加标签,以父评论子评论为例
  8. golang的time包:时间字符串和时间戳的相互转换
  9. echarts中国地图描绘
  10. mac必装软件