一、队列,先进先出(queue.Queue())
from queue import Queue
q = Queue(3) #指定队列的大小
q.put(1)
q.put(2)
q.put(3)
q.get()------>1, 2, 3
方法:
q.qsize()返回队列的大小
q.empty()如果队列为空,返回True
q.full()如果队列满了,返回True
q.get([block[, tmeout]]) 从队列中取出一个元素
q.put(item, timeout) 放入队列中一个元素
q.get_nowait()相当于q.get(False)
q.put_nowait()相当于q.put(False)
q.join()阻塞调用线程,直到队列中的所有任务被处理掉, 等队列为空在执行其他的任务
q.task_done()在完成一项工作后,函数向已完成的队列发送一个信号
二、基于优先级的队列(PriorityQueue)
from queue import PriorityQueue
q = PriorityQueue(3) 指定队列大小
q.put(1, ‘a’)
q.put(2, ‘d’)
q.put(-1, ‘s’)
q.get()------>s, a, d
使用数字表示优先级,数字越小优先级就越高,就先取出来
三、堆栈,后进先出
from queue import LifoQueue
q = LifoQueue(3) 指定堆栈大小
q.put(1)
q.put(2)
q.put(3)
q.get()----->3,2,1