1.在多线程和多进程中都有queue。调用方式不同,使用方式一致:
线程中:
import queue q = queue.Queue(maxsize = 2)
进程中:
from multiprocessing import Process, Queue q = Queue()
import queue
q = queue.Queue(maxsize = 2)
q.put(2)
q.put(4)
q.put(8,block=0) # 默认block为1 即满了就阻塞等待空位,改为0 会full报错
q.get() # get同理 拿不出来block为True时就阻塞
'''
Python Queue模块有三种队列及构造函数:
1、Python Queue模块的FIFO队列先进先出。 class queue.Queue(maxsize)
2、LIFO类似于堆,即先进后出。 class queue.LifoQueue(maxsize)
3、还有一种是优先级队列级别越低越先出来。 class queue.PriorityQueue(maxsize)
************一些方法
q.qsize() 返回队列的大小
q.empty() 如果队列为空,返回True,反之False
q.full() 如果队列满了,返回True,反之False
q.full 与 maxsize 大小对应
q.get([block[, timeout]]) 获取队列,timeout等待时间
q.get_nowait() 相当q.get(False)
非阻塞 q.put(item) 写入队列,timeout等待时间
q.put_nowait(item) 相当q.put(item, False)
q.task_done() 在完成一项工作之后,q.task_done() 函数向任务已经完成的队列发送一个信号
q.join() 实际上意味着等到队列为空,再执行别的操作
'''