C++,std::queue 详解
创作时间:
作者:
@小白创作中心
C++,std::queue 详解
引用
CSDN
1.
https://m.blog.csdn.net/Allen_Spring/article/details/141086755
1. 概述
std::queue 是 C++ 标准模板库(STL)中的一个容器适配器,它提供了一种先进先出(FIFO)的数据结构。std::queue 通常被用于存储元素集合,并且只允许在尾部添加新元素(push),在头部移除元素(pop)。这种特性使得 std::queue 成为实现队列行为的理想选择。
2. 包含头文件
要使用 std::queue,首先需要包含对应的头文件:
#include <queue>
3. 基本操作
3.1 构造函数
queue(): 默认构造函数,创建一个空的队列。queue(const queue& other): 拷贝构造函数,创建一个与other相同的队列。
3.2 赋值操作
queue& operator=(const queue& other): 赋值操作符,将other的内容赋值给当前队列。
3.3 成员函数
bool empty() const: 如果队列为空,则返回true;否则返回false。size_type size() const: 返回队列中元素的数量。void push(const value_type& val): 在队列尾部添加一个元素val。注意,对于 C++11 及更高版本,也支持右值引用版本的push(void push(value_type&& val)),这可以优化移动语义。void pop(): 移除队列头部的元素。如果队列为空,则行为未定义(通常是崩溃)。value_type& front(): 返回队列头部的元素的引用。如果队列为空,则行为未定义。const value_type& front() const: 返回队列头部的元素的常量引用。如果队列为空,则行为未定义。value_type& back(): 返回队列尾部的元素的引用。如果队列为空,则行为未定义。const value_type& back() const: 返回队列尾部的元素的常量引用。如果队列为空,则行为未定义。
4. 迭代器
std::queue 不提供迭代器支持,因为它被设计为仅通过其接口(如 front()、back()、push()、pop())来访问元素。如果你需要迭代访问元素,可能需要考虑使用 std::deque 或 std::list 作为底层容器(通过模板参数指定给 std::queue),但这将破坏 std::queue 提供的抽象和封装。
5. 示例
#include <iostream>
#include <queue>
int main() {
std::queue<int> myQueue;
// 向队列中添加元素
myQueue.push(10);
myQueue.push(20);
// 访问队列头部的元素
std::cout << "Front element is " << myQueue.front() << std::endl;
// 移除队列头部的元素
myQueue.pop();
// 访问新的队列头部的元素
std::cout << "New front element is " << myQueue.front() << std::endl;
// 检查队列是否为空
if (myQueue.empty()) {
std::cout << "Queue is empty." << std::endl;
} else {
std::cout << "Queue is not empty." << std::endl;
}
return 0;
}
6. 注意事项
- 使用
std::queue时,必须确保不会在队列为空时调用front()、back()或pop(),这会导致未定义行为(通常是程序崩溃)。 - 虽然
std::queue通常与std::deque一起使用作为底层容器(因为它是默认选择),但你也可以通过模板参数指定其他容器类型,如std::list。然而,这可能会影响性能。 std::queue不提供迭代器,因为其主要设计目标是提供一个简单的队列接口,而不是通用的容器接口。
热门推荐
特斯拉投资者因马斯克460亿美元薪酬方案发生分歧
AGI发展全面综述,我们还要多久到达AGI?
肝功能化验单,都说了啥?
收藏!这些用眼护眼指南和良好用眼习惯请收好
如何搬运大型床垫?搬运大型床垫有哪些技巧?
“无痛”真的会对孩子不好吗?
曹冲之死:历史真相与野史传闻的辨析
香气四溢的秘诀:如何正确冲泡茉莉花茶!
《重返未来1999》游戏类型介绍
老一辈常说碗筷不能隔夜洗?到底有什么道理呢?都有什么讲究呢?
大蒜重茬减产的防治技术
故意驾车撞行为的刑事法律责任与处罚分析
重装系统不丢失数据:保留重要软件与文件的技巧
项目规划PPT单页制作指南:从主题设定到最终呈现
栎木与橡木的差异及家具制作特点
巧读《三十六计》|“无中生有”的两大关键策略
宝马M3和M4在动力性能方面的差异
1080p是1920x1080吗
日语考级N2级的具体考试内容有哪些
TOPS:揭秘AI算力的度量单位
清宫图里生男孩的月份
纯电动汽车如何办理上牌手续?办理纯电动汽车上牌需要准备哪些材料?
数控机床培训就业前景怎么样?难学吗要学多久,考好不如选对!
Pascal 编程语言:从辉煌到传承
右侧肋骨里面疼是什么原因
怀孕鼻塞睡不好怎么办?教你4个非药物缓解方式
床垫如何送上高层才能安全便捷?这种运输方式有哪些要点?
迎接首个“非遗版”春节 八成受访者更重视过年习俗
如何理解股票投资中的本金风险
光伏电站组串式逆变器并联谐振问题深度解析