Queue模块支持先进先出(FIFO)队列,支持多线程的访问,包括一个主要的类型(Queue)和两个异常类(exception classes)。python
Python 2 中的Queue模块在Python 3中改名为 queue。多线程
Queue对象的建立spa
能够经过实例化Queue类型得到队列对象:线程
q = Queue.Queue(maxsize=0)
建立新的队列,参数 maxsize 的含义是:code
Queue模块定义的异常类对象
Queue.Empty
若是队列 q 是空的,此时又调用了 q.get(False),就会抛出该异常。blog
Queue.Full
若是队列q是满的,而又调用了 q.put(x, False),就会抛出该异常。队列
Queue对象的方法进程
q.empty()
判断队列是否为空。get
q.full()
判断队列是否已满。
q.get(block=True, timeout=None)
q.get_nowait()
参数 block 为 False 时,参数 timeout 没有意义,由于线程不会阻塞:
block 为 True 时,结合超时 timeout 判断当队列空时,是一直阻塞进程,仍是进程阻塞一段时间。
get_nowait()等于get(False),或者get(timeout=0)即不论队列空否,都不阻塞等待。
例如:
try: x = q.get_nowait() except Queue.Empty: print "no more items to process"
q.put(item, block=True, timeout=None)
q.put_nowait(item)
向队列中插入 item,若是队列满了,抛出Queue.Full或线程阻塞等待。
q.qsize()
返回当前队列中的元素个数。
q.join()
q.task_done()