PYTHON 多线程 实践
2013-06-16 15:32
281 查看
目标实现: 实现一个线程不断生成一个随机数到一个队列中
实现一个线程从上面的队列里面不断的取出奇数
实现另外一个线程从上面的队列里面不断取出偶数
Python中使用线程有两种方式:函数或者用类来包装线程对象。
函数式:调用thread模块中的start_new_thread()函数来产生新线程。或者创建threading.Thread的子类来包装一个线程对象。
此处采用第二种方式,即创建自己的线程类,必要时重写threading.Thread类的方法,线程的控制可以由自己定制。
最简单的同步机制就是“锁”。锁对象由threading.RLock类创建。
锁只能提供最基本的同步。假如只在发生某些事件时才访问一个“临界区”,这时需要使用条件变量Condition。PYTHON中QUEUE对象也提供对线程的同步支持。在此次实践中就是使用queue对象实现一个生产者和两个消费者形成的FIFO的队列。生产者将数据依次存入队列,消费者从队列取出数据。
输出结果
实现一个线程从上面的队列里面不断的取出奇数
实现另外一个线程从上面的队列里面不断取出偶数
Python中使用线程有两种方式:函数或者用类来包装线程对象。
函数式:调用thread模块中的start_new_thread()函数来产生新线程。或者创建threading.Thread的子类来包装一个线程对象。
此处采用第二种方式,即创建自己的线程类,必要时重写threading.Thread类的方法,线程的控制可以由自己定制。
最简单的同步机制就是“锁”。锁对象由threading.RLock类创建。
锁只能提供最基本的同步。假如只在发生某些事件时才访问一个“临界区”,这时需要使用条件变量Condition。PYTHON中QUEUE对象也提供对线程的同步支持。在此次实践中就是使用queue对象实现一个生产者和两个消费者形成的FIFO的队列。生产者将数据依次存入队列,消费者从队列取出数据。
from Queue import Queue import random import threading import time #Producer thread class Producer(threading.Thread): def __init__(self, t_name, queue): threading.Thread.__init__(self, name=t_name) self.data=queue def run(self): for i in range(10): #随机产生10个数字 ,可以修改为任意大小 randomnum=random.randint(1,99) print "%s: %s is producing %d to the queue!\n" %(time.ctime(), self.getName(), randomnum) self.data.put(randomnum) #将数据依次存入队列 time.sleep(1) print "%s: %s finished!" %(time.ctime(), self.getName()) #Consumer thread class Consumer_even(threading.Thread): def __init__(self, t_name, queue): threading.Thread.__init__(self, name=t_name) self.data=queue def run(self): while True: try: val_even = self.data.get(1,5) #get(self, block=True, timeout=None) ,1就是阻塞等待,5是超时5秒 if val_even%2==0: print "%s: %s is consuming. %d in the queue is consumed!\n" %(time.ctime(), self.getName(), val_even) time.sleep(2) else : self.data.put(val_even) time.sleep(2) except: #等待输入,超过5秒 就报异常 print "%s: %s finished!" %(time.ctime(), self.getName()) break class Consumer_odd(threading.Thread): def __init__(self, t_name, queue): threading.Thread.__init__(self, name=t_name) self.data=queue def run(self): while True: try: val_odd = self.data.get(1,5) if val_odd%2!=0: print "%s: %s is consuming. %d in the queue is consumed!\n" %(time.ctime(), self.getName(), val_odd) time.sleep(2) else : self.data.put(val_odd) time.sleep(2) except: print "%s: %s finished!" %(time.ctime(), self.getName()) break #Main thread def main(): queue = Queue() producer = Producer('Pro.', queue) consumer_even = Consumer_even('Con_even.', queue) consumer_odd = Consumer_odd('Con_odd.',queue) producer.start() consumer_even.start() consumer_odd.start() producer.join() consumer_even.join() consumer_odd.join() print 'All threads terminate!' if __name__ == '__main__': main()
输出结果
相关文章推荐
- Python的多线程与多进程实践
- python多线程实践小结
- python之多线程 queue 实践 筛选有效url
- python threading模块使用 以及python多线程操作的实践(使用Queue队列模块)
- python之多线程 threading.Lock() 和 threading.RLock()
- Python 多线程
- 《python数据挖掘入门与实践》“电影推荐” 笔记3
- python 多线程中同步的小例子
- 【Python】多线程
- [Python]多线程网址爬虫:控制线程数,爬虫深度
- Python多线程结合队列下载百度音乐的方法
- Python tkinter多进程多线程前邮箱,再用pyinstaller编译成exe
- Python多线程thread与threading实现
- python_多线程
- python 多线程就这么简单
- 深度学习:python教程 实践(一)
- Python(2.7.x)多线程的简单示例
- Python程序设计与算法基础教程·第八章上机实践
- Python-Django 使用 Hudson做CI服务器实践记
- Python 装饰器学习以及实际使用场景实践