C++初阶——queue
一、什么是queue
是一个容器适配器,专门设计用于在先进先出(FIFO,First In First Out)的上下文中操作。它是一个容器适配器,这意味着它不是一个完整的容器类,而是封装了一个特定的容器类(如list,deque等)作为其底层容器,并提供了一组特定的成员函数来访问其元素。
二、queue的定义及初始化
2.1queue的定义
#include<iostream>
#include<queue>
using namespace std;int main()
{queue<内置类型>q1; //定义一个储存数据类型为int的queue容器q1 queue<自定义类型>q2; //定义一个储存数据类型为结构体类型的queue容器q2return 0;
}
2.2queue的初始化
#include <iostream>
#include <queue>
#include <vector>
using namespace std;int main() {vector<int> v = { 1,2,4 };queue<int,vector<int>> q1(v);//用另一个容器进行初始化,第二个参数为用来初始化的容器类型
}
三、queue成员函数
3.1empty函数
bool empty() const;//函数原型
返回队列是否为空:即其大小是否为零。这个成员函数实际上调用了底层容器对象的empty成员函数。
#include <queue>
#include <vector>
#include <iostream>
using namespace std;int main() {vector<int> v = { 1,2,4 };queue<int, vector<int>> q1(v);queue<int> q2;cout << q1.empty() << endl;//s1不为空,所以返回值为0cout << q2.empty() << endl;//s2是一个空队列,返回值是1
}
3.2size函数
size_type size() const;
返回队列中的元素数量。这个成员函数实际上调用了底层容器对象的size成员函数。
#include <queue>
#include <vector>
#include <iostream>
using namespace std;int main() {vector<int> v = { 1,2,4 };queue<int, vector<int>> q1(v);queue<int> q2;cout << q1.size() << endl;cout << q2.size() << endl;
}
3.3front函数和back函数
reference& front();
const_reference& front() const;reference& back();
const_reference& back() const;
front函数实际上是调用了底层容器对象的front成员函数。queue通常使用deque作为其底层容器,但也可以是其他容器,如list。无论使用哪种底层容器,front函数都会调用该容器的front方法来获取队列前端的元素。back函数同理
#include <queue>
#include <vector>
#include <iostream>
using namespace std;int main() {vector<int> v = { 1,2,4 };queue<int, vector<int>> q1(v);cout << q1.front() << endl;cout << q1.back() << endl;
}
3.4push函数
void push (const value_type& val);
void push (value_type&& val);
push函数用于在队列末尾插入一个新元,实际上是调用了底层容器对象的push_back成员函数。
#include <queue>
#include <vector>
#include <iostream>
using namespace std;int main() {vector<int> v = { 1,2,4 };queue<int, vector<int>> q1(v);q1.push(10);cout << q1.front() << endl;cout << q1.back() << endl;
}
3.5pop函数
void pop();
pop函数将移除队列前端的一个元素,从而将队列的大小减少一。如果队列为空,pop操作可能会抛出一个异常,具体取决于底层容器的实现。
vector中没有pop_front成员函数,所以可能会需要程序员手动使用erase成员函数实现pop_front函数。
#include <queue>
#include <iostream>
using namespace std;int main() {deque<int> d = { 1,2,4 };queue<int> q1(d);//queue底层默认是dequeq1.pop();cout << q1.front() << endl;cout << q1.back() << endl;
}
3.6emplace函数
template <class... Args> void emplace (Args&&... args);
如果你想要就地构造一个新元素而不是复制或移动现有元素,你可以使用emplace方法。emplace方法允许你传递构造新元素所需的参数,这些参数会被转发到底层容器emplace_back 方法,后者会在容器的末尾就地构造新元素。
#include <stack>
#include <queue>
#include <iostream>
using namespace std;class A
{
public:int _a;int _b;A(int a = 0, int b = 0):_a(a), _b(b){}
};int main() {queue<A> q;A a;q.push(a);q.emplace(10, 10);cout << q.front()._a << endl;q.pop();cout << q.front()._a << endl;
}
3.7swap函数
void swap (queue& x) noexcept(/*see below*/);
这里的注释/*see below*/指的是noexcept后面的表达式,它用于指定该函数是否可能抛出异常。在queue的swap成员函数中,这个表达式依赖于底层容器的swap函数是否可能抛出异常。
swap函数交换两个queue对象的内容。这是通过交换底层容器实现的,因为queue是一个容器适配器,它不直接存储元素,而是依赖于一个底层容器。
#include <vector>
#include <queue>
#include <iostream>
using namespace std;int main() {vector<int> v1 = { 1,2,3 };vector<int> v2 = { 4,5,6 };queue<int, vector<int>> q1(v1);queue<int, vector<int>> q2(v2);cout << q1.front() << endl;cout << q2.front() << endl;q1.swap(q2);cout << q1.front() << endl;cout << q2.front() << endl;
}
也可以用模板swap函数。
#include <vector>
#include <queue>
#include <iostream>
using namespace std;int main() {vector<int> v1 = { 1,2,3 };vector<int> v2 = { 4,5,6 };queue<int, vector<int>> q1(v1);queue<int, vector<int>> q2(v2);cout << q1.front() << endl;cout << q2.front() << endl;swap(q1,q2);cout << q1.front() << endl;cout << q2.front() << endl;
}
四、运算符重载
queue提供的比较运算符重载会将比较操作委托给其底层容器对象。这意味着,当你比较两个queue对象时,实际上是在比较它们底层容器中存储的元素序列。这点与stack容器适配器是一样的。
相关文章:
C++初阶——queue
一、什么是queue 是一个容器适配器,专门设计用于在先进先出(FIFO,First In First Out)的上下文中操作。它是一个容器适配器,这意味着它不是一个完整的容器类,而是封装了一个特定的容器类(如list…...
达梦数据库迁移j脚本
国产环境使用达梦数据库的越来越多,除了使用管理工具,还是可以使用脚本。 下面简单记录下,我在迁移中遇到的问题: 备份脚本 使用此脚本可以一次备份一个数据 backup_one_db.sh #!/bin/bashexport DB$1 export PASS<your_p…...
【Linux】内核调用栈打印函数dump_stack使用效果
init/main.c的start_kernel示例,这个调用栈不太深: /var/log/dmesg日志: [ 0.000000] kernel: [init/main.c start_kernel 911] start_kernel(void) [ 0.000000] kernel: [kernel/panic.c print_tainted 519 LOG_TIMES: 1 ] [ 0.…...
Uniapp踩坑input自动获取焦点ref动态获取实例不可用
前言 大家好我是没钱的君子下流坯,用自己的话解释自己的知识。很久很更新了,这几个月一直在加班,今天记录一个uniapp关于input中focus()方法自动获取焦点的坑。 案例 为了实现一个手机验证码的页面,验证码是五个输入框…...
数据分析-47-时间序列变点检测之离线历史数据的CPD
文章目录 1 时间序列结构1.1 变化点的定义1.2 结构变化的类型1.2.1 水平变化1.2.2 方差变化1.3 变点检测1.3.1 离线数据检测方法1.3.2 实时数据检测方法2 模拟数据2.1 模拟恒定方差数据2.2 模拟变化方差数据3 离线数据变点检测3.1 Ruptures模块3.2 恒定方差CPD3.3 变化方差CPD4…...
加入GitHub Spark需要申请
目录 加入GitHub Spark需要申请 GitHub Spark 一、产品定位与特点 二、核心组件与功能 三、支持的AI模型 四、应用场景与示例 五、未来展望 六、申请体验 加入GitHub Spark需要申请 GitHub Spark 是微软旗下GitHub在2024年10月30日的GitHub Universe大会上推出的一款革…...
生成式GPT商品推荐:精准满足用户需求
生成式GPT商品推荐:精准满足用户需求 随着人工智能(AI)技术的飞速发展,电商平台正在逐步迎来一场前所未有的变革。尤其是生成式GPT(Generative Pre-trained Transformer)技术的应用,正在重新定…...
async 和 await的使用
一、需求 点击按钮处理重复提交,想要通过disabled的方式实现。 但是点击按钮调用的方法里有ajax、跳转、弹窗等一系列逻辑操作,需要等方法里流程都走完,再把disabled设为false,这样下次点击按钮时就可以继续走方法里的ajax等操作…...
Spring Cloud Vault快速入门Demo
1.什么是Spring Cloud Vault? Spring Cloud Vault 是 Spring Cloud 生态系统中的一个项目,旨在简化 Spring 应用程序与 HashiCorp Vault 的集成。它提供了一种方便的方式来管理和访问应用程序的敏感配置数据,如数据库凭证、API 密钥和其他机…...
道陟科技EMB产品开发进展与标准设计的建议|2024电动汽车智能底盘大会
11月12日,2024电动汽车智能底盘大会在重庆开幕。会议由中国汽车工程学会主办,电动汽车产业技术创新战略联盟、中国汽车工程学会智能底盘分会、智能绿色车辆与交通全国重点实验室承办。本届大会围绕电动汽车智能底盘相关技术发展与融合,满足高…...
GitHub Org
运营一个GitHub Org(组织)是一个复杂但充满价值的过程,它涉及多个方面,包括项目管理、团队协作、代码审查、文档维护、社区建设等。以下是一篇关于如何运营GitHub Org的详细指南,旨在帮助组织者更好地管理和维护其GitH…...
unity小:shaderGraph不规则涟漪、波纹效果
实现概述 在本项目中,我们通过结合 Sine、Polar Coordinates 和 Time 节点,实现了动态波纹效果。以下是实现细节: 核心实现 Sine 波形生成: 使用 Sine 节点生成基本的波形。该节点能够创建周期性变化,为波纹效果提供…...
【JavaScript】JavaScript开篇基础(6)
1.❤️❤️前言~🥳🎉🎉🎉 Hello, Hello~ 亲爱的朋友们👋👋,这里是E绵绵呀✍️✍️。 如果你喜欢这篇文章,请别吝啬你的点赞❤️❤️和收藏📖📖。如果你对我的…...
Spark RDD、DStream、DataFrame、DataSet 在窗口操作上的区别
Spark RDD、DStream、DataFrame、DataSet 在窗口操作上的区别 1. Spark RDD 是否支持窗口操作: RDD 本身没有专门的窗口操作算子。原因: RDD 是一个弹性分布式数据集,设计为通用的、不可变的操作单元,主要用于批处理场景。窗口函…...
http自动发送请求工具(自动化测试http请求)
点击下载《http自动发送请求工具(自动化测试http请求)》 前言 在现代软件开发过程中,HTTP 请求的自动化测试是确保应用程序稳定性和可靠性的关键环节。为了满足这一需求,我开发了一款功能强大且易于使用的自动化 HTTP 请求发送工具。该工具基于 C# 开发…...
网络IP地址会经常换吗?深入解析与实操指南
在互联网的生态系统中,IP地址(Internet Protocol Address)是每台连接设备的唯一标识符,它在网络通信中起着至关重要的作用。然而,不少用户观察到自己的IP地址有时会发生变化,这引发了诸多疑问。本文旨在详细…...
MapLocNet由粗到细的定位网络
论文链接 MapLocNet: Coarse-to-Fine Feature Registration for Visual Re-Localization in Navigation Mapshttps://arxiv.org/html/2407.08561v1 问题背景 当前自动驾驶的定位主要依赖于高精度的地图和GPS信号,但在城市环境中,GPS信号易受到多路径传…...
【Docker】Mac安装Docker Desktop导致磁盘剩余空间较少问题如何解决?
目录 一、背景描述 二、解决办法 三、清理效果 四、理论参考 解决方法 1. 清理未使用的 Docker 镜像、容器和卷 2. 查看 Docker 使用的磁盘空间 3. 调整 Docker 的存储位置 4. 增加磁盘空间 5. 调整 Docker Desktop 配置 6. 使用 Docker 清理工具(例如 D…...
构建客服知识库:企业效率提升的关键步骤
客服知识库是企业提升客户服务效率和质量的重要工具。它不仅帮助客服团队快速准确地回答客户问题,还能通过数据分析来优化服务流程和提升客户满意度。 1. 明确知识库的目标和范围 构建客服知识库的第一步是明确其目标和范围。这包括确定知识库的主要用户群体、需要…...
java-Day06 内部类 Lambda表达式 API
内部类 内部类:就是在一个类中定义一个类 格式例: public class Outer { public class Inner { } } 内部类分类 1.成员内部类(了解) 创建成员内部类 外部类.内部类 对象名new外部类().new内部类() 2.静态内部类(了解) 3.局部内部类(了解) 4.匿名内部类…...
云原生核心技术 (7/12): K8s 核心概念白话解读(上):Pod 和 Deployment 究竟是什么?
大家好,欢迎来到《云原生核心技术》系列的第七篇! 在上一篇,我们成功地使用 Minikube 或 kind 在自己的电脑上搭建起了一个迷你但功能完备的 Kubernetes 集群。现在,我们就像一个拥有了一块崭新数字土地的农场主,是时…...
NFT模式:数字资产确权与链游经济系统构建
NFT模式:数字资产确权与链游经济系统构建 ——从技术架构到可持续生态的范式革命 一、确权技术革新:构建可信数字资产基石 1. 区块链底层架构的进化 跨链互操作协议:基于LayerZero协议实现以太坊、Solana等公链资产互通,通过零知…...
【学习笔记】深入理解Java虚拟机学习笔记——第4章 虚拟机性能监控,故障处理工具
第2章 虚拟机性能监控,故障处理工具 4.1 概述 略 4.2 基础故障处理工具 4.2.1 jps:虚拟机进程状况工具 命令:jps [options] [hostid] 功能:本地虚拟机进程显示进程ID(与ps相同),可同时显示主类&#x…...
技术栈RabbitMq的介绍和使用
目录 1. 什么是消息队列?2. 消息队列的优点3. RabbitMQ 消息队列概述4. RabbitMQ 安装5. Exchange 四种类型5.1 direct 精准匹配5.2 fanout 广播5.3 topic 正则匹配 6. RabbitMQ 队列模式6.1 简单队列模式6.2 工作队列模式6.3 发布/订阅模式6.4 路由模式6.5 主题模式…...
论文笔记——相干体技术在裂缝预测中的应用研究
目录 相关地震知识补充地震数据的认识地震几何属性 相干体算法定义基本原理第一代相干体技术:基于互相关的相干体技术(Correlation)第二代相干体技术:基于相似的相干体技术(Semblance)基于多道相似的相干体…...
RabbitMQ入门4.1.0版本(基于java、SpringBoot操作)
RabbitMQ 一、RabbitMQ概述 RabbitMQ RabbitMQ最初由LShift和CohesiveFT于2007年开发,后来由Pivotal Software Inc.(现为VMware子公司)接管。RabbitMQ 是一个开源的消息代理和队列服务器,用 Erlang 语言编写。广泛应用于各种分布…...
STM32HAL库USART源代码解析及应用
STM32HAL库USART源代码解析 前言STM32CubeIDE配置串口USART和UART的选择使用模式参数设置GPIO配置DMA配置中断配置硬件流控制使能生成代码解析和使用方法串口初始化__UART_HandleTypeDef结构体浅析HAL库代码实际使用方法使用轮询方式发送使用轮询方式接收使用中断方式发送使用中…...
Golang——7、包与接口详解
包与接口详解 1、Golang包详解1.1、Golang中包的定义和介绍1.2、Golang包管理工具go mod1.3、Golang中自定义包1.4、Golang中使用第三包1.5、init函数 2、接口详解2.1、接口的定义2.2、空接口2.3、类型断言2.4、结构体值接收者和指针接收者实现接口的区别2.5、一个结构体实现多…...
消防一体化安全管控平台:构建消防“一张图”和APP统一管理
在城市的某个角落,一场突如其来的火灾打破了平静。熊熊烈火迅速蔓延,滚滚浓烟弥漫开来,周围群众的生命财产安全受到严重威胁。就在这千钧一发之际,消防救援队伍迅速行动,而豪越科技消防一体化安全管控平台构建的消防“…...
leetcode_69.x的平方根
题目如下 : 看到题 ,我们最原始的想法就是暴力解决: for(long long i 0;i<INT_MAX;i){if(i*ix){return i;}else if((i*i>x)&&((i-1)*(i-1)<x)){return i-1;}}我们直接开始遍历,我们是整数的平方根,所以我们分两…...
