queue是python3的内置模块,创建堆栈队列,用来处理多线程通信,队列对象构造方法如下:
queue.Queue(maxsize=0)
是先进先出(First In First Out: FIFO)队列。
入参 maxsize 是一个整数,用于设置队列的最大长度。一旦队列达到上限,插入数据将会被阻塞,直到有数据出队列之后才可以继续插入。如果 maxsize 设置为小于或等于零,则队列的长度没有限制。
主要方法有如下几个:
- qsize():返回队列中数据元素的个数。
- empty():如果队列为空,返回 True,否则返回 False。
- full():如果队列中元素个数达到上限,返回 True,否则返回 False。
- put(item, block=True, timeout=None):
- item,放入队列中的数据元素。
- block和timeout参数,当队列中元素个数达到上限继续往里放数据时:
- 如果 block=False,直接引发 Full 异常;
- 如果 block=True,且 timeout=None,则一直等待直到有数据出队列后可以放入数据;
- 如果 block=True,且 timeout=N,N 为某一正整数时,则等待 N 秒,如果队列中还没有位置放入数据就引发 Full 异常。timeout,设置超时时间。
- put_nowait(item)相当于 put(item, block=False),当队列中元素个数达到上限继续往里放数据时直接引发 Full 异常。
- get(block=True, timeout=None):从队列中取出数据并返回该数据内容。
- block,当队列中没有数据元素继续取数据时:
- 如果 block=False,直接引发Empty 异常;
- 如果 block=True,且 timeout=None,则一直等待直到有数据入队列后可以取出数据;
- 如果 block=True,且 timeout=N,N 为某一正整数时,则等待 N 秒,如果队列中还没有数据放入的话就引发 Empty 异常。timeout,设置超时时间。
- block,当队列中没有数据元素继续取数据时:
- get_nowait():相当于 get(block=False)block,当队列中没有数据元素继续取数据时直接引发 Empty 异常。
简单使用示例
import queue
q = queue.Queue() # 创建 Queue 队列
for i in range(3):
q.put(i) # 在队列中依次插入0、1、2元素
for i in range(3):
print(q.get()) # 依次从队列中取出插入的元素,数据元素输出顺序为0、1、2
end