0

0

C++中queue怎么使用_C++标准库队列容器常用操作指令【速查】

尼克

尼克

发布时间:2026-02-16 16:25:35

|

514人浏览过

|

来源于php中文网

原创

std::queue是fifo适配器,底层默认为std::deque,不支持随机访问、遍历或查找;声明仅支持空初始化或以兼容容器构造,无花括号初始化;pop()不返回值,须先front()再pop(),且调用前必须检查empty();因其屏蔽非fifo接口,遍历或查找需换用std::deque等容器。

c++中queue怎么使用_c++标准库队列容器常用操作指令【速查】

直接说结论:C++ 的 std::queue 是适配器容器,底层默认用 std::deque 实现,不支持随机访问、遍历或查找,只提供 FIFO(先进先出)的受限接口。

怎么声明和初始化 std::queue

它不能像 std::vector 那样用花括号初始化元素,因为没有公开的构造函数接收初始化列表(C++11 起虽有,但仅限于从另一个容器构造,且仍不支持直接写 {1,2,3})。常见写法只有:

  • 空队列:std::queue<int> q;</int>
  • 用其他容器初始化(需类型兼容):std::deque<int> d = {1, 2, 3}; std::queue<int> q(d);</int></int>
  • 指定底层容器类型(如改用 std::list):std::queue<int std::list>> q;</int>

注意:std::queue 没有 begin()/end(),所以无法用范围 for 循环直接遍历——这是初学者最常卡住的地方。

push()pop()front()/back() 的正确调用顺序

这三个操作必须配合使用,且 pop() 不返回值,只移除队首。常见错误是想“弹出并获取”一步完成:

立即学习C++免费学习笔记(深入)”;

Grammarly
Grammarly

Grammarly是一款在线语法纠正和校对工具,伟大的AI辅助写作工具

下载
  • ✅ 正确:先 front() 取值,再 pop() 移除:int x = q.front(); q.pop();
  • ❌ 错误:int x = q.pop(); —— pop() 返回 void,编译失败
  • ⚠️ 危险:q.front()q.back() 在空队列上调用 —— 行为未定义(通常 crash)

务必在取 front() 前检查 q.empty()back() 同理,且只在非空时有效。

为什么不能用 std::queue 查找或遍历元素

因为 std::queue 是适配器(adapter),它封装了底层容器,并**显式屏蔽了所有非 FIFO 接口**。即使你传入 std::vector 作底层,也无法通过 queue 对象访问其下标或迭代器。

  • 想遍历?只能反复 front()+pop(),但这样会清空原队列
  • 想查找某值?必须自己写循环 + 临时存储,或换用 std::deque/std::list
  • 性能提示:用 std::deque 作底层时,push()/pop() 均为均摊 O(1);若强制用 std::vectorpush() 在扩容时可能 O(n)

替代方案:什么时候该放弃 std::queue

当需求超出“纯 FIFO”时,就该换容器了。比如:

  • 需要中间插入/删除 → 用 std::deque
  • 需要按值查找或遍历 → 用 std::dequestd::list
  • 需要线程安全 → std::queue 本身不提供锁,得自己加 std::mutex
  • 需要优先级调度 → 改用 std::priority_queue

别为了“名字叫 queue”而硬套;标准库选型的核心是看接口契约是否匹配实际操作,而不是名称是否贴切。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

750

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

568

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

234

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

209

2025.08.29

javascriptvoid(o)怎么解决
javascriptvoid(o)怎么解决

javascriptvoid(o)的解决办法:1、检查语法错误;2、确保正确的执行环境;3、检查其他代码的冲突;4、使用事件委托;5、使用其他绑定方式;6、检查外部资源等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

182

2023.11.23

java中void的含义
java中void的含义

本专题整合了Java中void的相关内容,阅读专题下面的文章了解更多详细内容。

114

2025.11.27

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1465

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

383

2025.10.17

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

145

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 9.5万人学习

C 教程
C 教程

共75课时 | 4.8万人学习

C++教程
C++教程

共115课时 | 18万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号