利用python线程编程实现生产者与消费者关系
来源:互联网 发布:java链接oracle数据库 编辑:程序博客网 时间:2024/05/01 08:01
python中,有thread和threading模块支持多线程编程,而threading是thread的封装,所以一般情况下使用threading模块进行编程。
对于生产者和消费者关系的python实现,代码如下:
import threading
class Producer(threading.Thread):
def __init__(self, threadname):
threading.Thread.__init__(self, name = threadname)
def run(self):
global x
con.acquire()
if x == 1000000:
con.wait()
pass
else:
for i in range(1000000):
x = x + 1
con.notify()
print x
con.release()
class Consumer(threading.Thread):
def __init__(self, threadname):
threading.Thread.__init__(self, name = threadname)
def run(self):
global x
con.acquire()
if x == 0:
con.wait()
pass
else:
for i in range(1000000):
x = x-1
con.notify()
print x
con.release()
con = threading.Condition()
x = 0
p = Producer('Producer')
c = Consumer('Consumer')
p.start()
c.start()
p.join()
c.join()
print x
其中,join()方法用于等待线程完成,acquire和release方法用于线程同步
运行结果:
在python中可以使用Queue对象实现多个生产者和多个消费者的关系模型,下面代码是一个简单的实现:
import threading
import time
import Queue
class producer(threading.Thread):
def __init__(self, threadname):
threading.Thread.__init__(self, name = threadname)
def run(self):
global queue
queue.put(self.getName())
print self.getName(), 'put ', self.getName(), ' to queue'
class consumer(threading.Thread):
def __init__(self, threadname):
threading.Thread.__init__(self, name = threadname)
def run(self):
global queue
print self.getName(), 'get ', queue.get(), 'from queue'
queue = Queue.Queue()
prolist = []
conlist = []
for i in range(10):
p = producer('Producer' + str(i))
prolist.append(p)
for i in range(10):
c = consumer('Consumer' + str(i))
conlist.append(c)
for i in prolist:
i.start()
i.join()
for i in conlist:
i.start()
i.join()
运行结果:
- 利用python线程编程实现生产者与消费者关系
- python核心编程-线程threading模块之生产者与消费者
- 利用两个线程实现生产者消费者模型
- 生产者与消费者,通过线程去实现
- 线程生产者与消费者
- 线程---生产者与消费者
- Python中的生产者与消费者 实现多线程
- Linux C:利用两个线程实现生产者消费者模型
- python生产者与消费者模式:队列实现线程通信、ThreadLocal、GIL
- 利用python实现生产者消费者的并发模型
- 利用ArrayBlockingQueue实现生产者-消费者
- 利用BlockingQueue实现生产者消费者
- 【Linux】生产者消费者编程实现-线程池+信号量
- 【Linux】生产者消费者编程实现-线程池+信号量
- c#线程实现生产者消费者
- 线程实现生产者消费者实验
- 生产者和消费者线程实现
- 线程(消费者与生产者)
- 互动网最新图书活动!
- linux sed应用收集
- jquery 小技巧
- DataTable各种方法总结(给Datatable添加行列、DataTable选择排序等
- 推荐13款JavaScript图形和图表绘制工具
- 利用python线程编程实现生产者与消费者关系
- TRAC 以及 nexus
- 关于LDO芯片的选型问题
- 关于PE文件格式中IMAGE_OPTIONAL_HEADER.FileAlignment的一些说明
- CReg类轻松读取注册表
- 基于 Android NDK 的学习之旅-----目录
- Windbg检查托管代码的内存泄露
- 关于firefox(火狐浏览器)document.all和document.layers
- 学会控制自己的情绪