转载*请注明原始出处: http://blog.csdn.net/a464057216/article/details/48103125
后续此博客不再更新,欢迎大家搜索关注微信公众号“测开之美”,测试开发工程师技术修炼小站,持续学习持续进步。
Queue模块提供了对“多生产者,多消费者”队列模型的支持,是线程安全的模块,在多线程之间传递数据时尤其有用。如果只是想使用队列这种数据结构,可以参考collections.deque模块。
Queue模块内包含三种队列:
- class Queue.Queue(maxsize = 0):FIFO队列,maxsize指定了队列的大小,如果队列已满,将不能插入新的元素,除非队列中有元素被消耗。如果maxsize为零或者负数,则队列的大小是无限大。
- class Queue.LifoQueue(maxsize = 0):LIFO队列,maxsize的含义与Queue.Queue中一致。
- class Queue.PriorityQueue(maxsize = 0):优先级队列(内部其实由heapq模块实现),maxsize的含义与Queue.Queue中一致。优先级最小的项目被优先取出,优先级的排序其实是根据sorted(list(entries)[0])的结果,每个项目的格式是(priority_number, data)的元组。
Queue模块还有两种异常,是上面三种队列公用的:
- exception Queue.Empty:当一个Queue对象中无元素,却对这个Queue对象调用了非阻塞的get()或者get_nowait()方法的时候抛出。
- exception Queue.Full:当一个Queue对象中元素已满,却对这个Queue对象调用了非阻塞的put()或者put_nowait()方法的时候抛出。
Queue模块还提供