python队列
1、首先导入库
python
import queue
2、普通队列
python
import queue
q = queue.Queue()
# 添加元素
q.put("a")
q.put("b")
# 删除并返回元素
print(q.get()) # 输出: a
# 检查队列是否为空
print(q.empty()) # 输出: False
q.queue.clear() # 清空队列
3、后进先出队列
这是一个后进先出 (LIFO) 的队列,也就是通常所说的栈。
python
from queue import LifoQueue
q = LifoQueue()
q.put('a')
q.put('b')
q.put('c')
print(q.get()) # 输出: c
4、优先级队列
这是一个优先队列。队列中的每个元素都是一个元组 (priority, data),其中 priority 是一个可以比较的值。
python
from queue import PriorityQueue
q = PriorityQueue()
q.put((2, 'a'))
q.put((1, 'b'))
q.put((3, 'c'))
print(q.get()[1]) # 输出: b 返回优先级最低的项
5、常见方法:
put(item): 将一个元素添加到队列。
get(): 从队列中删除并返回一个元素。如果队列为空,此方法将会阻塞,直到有元素可用。
empty(): 如果队列为空,返回 True,否则返回 False。
full(): 如果队列已满,返回 True,否则返回 False。
put_nowait(item): 等同于 put(item),但不阻塞。
get_nowait(): 等同于 get(),但不阻塞。
注意:在多线程环境中,queue 模块的队列是线程安全的,因此经常被用作线程之间的通信工具。