queue队列

python2.x  Queue   python3.x  queuepython

做用:一、提升效率;二、完成程序的解耦。python3.x

队列能够理解为一个有序的容器,但跟列表不一样的是,队列里的数据取出来就没有了。函数

class queue.Queue(maxsize=0)    先入先出spa

class queue.LifoQueue(maxsize=0)  后入先出(last in first out)code

class queue.PriorityQueue(maxsize=0)  存储数据时能够设置优先级的队列orm

Queue.put(item, block=True, timeout=None)   往队列里放数据(block表示若是满了是否等待取出)blog

Queue.get(block=True, timeout=None)   往队列里取数据(若是队列里没有数据就一直等待,由于block默认为True表示阻塞,timeout能够设置等待时间)队列

Queue.get_nowait()   往队列里取数据(不等待,若是没有数据就抛出异常)utf-8

Queue.qsize()   队列大小get

Queue.empty()    是否为空

Queue.full()  是否满了

Queue.task_done() 在完成一项工做以后,Queue.task_done()函数向任务已经完成的队列发送一个信号

Queue.join() 实际上意味着等到队列为空,再执行别的操做

 

加入队列时设置优先级的例子(按元组的第一个元素升序排列)

import Queue

q = Queue.PriorityQueue()

q.put((6, 'vivi'))
q.put((1, 'Allen'))
q.put((3, 'Jackson'))

print q.get()
print q.get()
print q.get()

输出:
(1, 'Allen')
(3, 'Jackson')
(6, 'vivi')

 

生产者消费者模型

#coding=utf-8

import threading
import Queue
import time

q = Queue.Queue(maxsize=10)

def writer():
    index = 1
    while True:
        print u'辉哥写出了bug{}'.format(index)
        q.put('bug{}'.format(index))
        time.sleep(1)
        index += 1

def tester():
    while True:
        print u'华哥测出了{}'.format(q.get())
        time.sleep(0.5)

wt = threading.Thread(target=writer)
tt = threading.Thread(target=tester)

wt.start()
tt.start()

运行结果:

辉哥写出了bug1
华哥测出了bug1
辉哥写出了bug2
华哥测出了bug2
辉哥写出了bug3
华哥测出了bug3
辉哥写出了bug4
华哥测出了bug4
辉哥写出了bug5
华哥测出了bug5
辉哥写出了bug6
华哥测出了bug6
...
相关文章
相关标签/搜索