python3学习-Queue模块
python标准库中带有一个Queue模块,顾名思义,队列。该模块也衍生出一些基本队列不具有的功能。
我们先看一下队列的方法:
put | 存数据 |
get | 取数据 |
empty | 判断队列是否为空 |
qsize | 显示队列中真实存在的元素长度 |
maxsize | 最大支持队列长度 |
join | 等到队列为空,该行语句下面的语句才会执行 |
full | 检查队列是否已满 |
单向队列
import queue
q = queue.Queue(5)
print(q.maxsize)
q.put(343)
q.put(23)
q.put(432)
print(q.get())
q.put(44)
q.put(35)
q.put(235)
print(q.full()) #判断队列当前大小是否等于约定队列大小
print(q.qsize())
先进后出队列
q = queue.LifoQueue(5)
q.put(343)
q.put(23)
q.put(432)
print(q.get())
优先级队列
优先级队列put进去的是一个元祖,(优先级,数据),优先级数字越小,优先级越高
q = queue.PriorityQueue(5)
q.put((5, 5454))
q.put((5, 532566))
q.put((3, 555))
q.put((7, 344))
print(q.get())
print(q.get())
注意:如果有两个元素优先级是一样的,那么在出队的时候是按照先进先出的顺序的。
双端队列
q = queue.deque()
q.append(1) #这个方法是在尾部增加
q.append(2)
q.append(3)
q.appendleft(4) #这个方法是在首部增加
q.insert(2,5) #指定位置插入元素
print(q.pop()) #出队是尾部先出
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构