【C++初阶】STL详解(七)Stack与Queue的模拟实现
本专栏内容为:C++学习专栏,分为初阶和进阶两部分。 通过本专栏的深入学习,你可以了解并掌握C++。
💓博主csdn个人主页:小小unicorn
⏩专栏分类:C++
🚚代码仓库:小小unicorn的代码仓库🚚
🌹🌹🌹关注我带你学习编程知识
STL详解(八)
- 容器适配器
- stack的模拟实现:
- queue的模拟实现:
容器适配器
stack和queue有一点需要注意的是,虽然stack和queue中也可以存放元素,但在STL中并没有将其划分在容器的行列,而是将其称为容器适配器,这是因为stack和queue只是对其他容器的接口进行了包装,STL中stack和queue默认使用deque容器。
在stack和queue的类模板声明当中我们就可以看到,它们的模板参数有两个,第一个是stack和queue当中所存储的元素类型,而另一个就是指定使用的容器类型。只不过当我们不指定使用何种容器的情况下,stack和queue都默认使用deque作为指定容器。

理解: 学过数据结构后我们都知道,stack和queue既可以使用顺序表实现,也可以使用链表实现。
在这里我们若是定义一个stack,并指定使用vector容器,则定义出来的stack实际上就是对vector容器进行了包装
stack的模拟实现:
知道了容器适配器后,stack的模拟实现就显得相当简单,我们只需要调用所指定容器的各个成员函数即可实现stack的各个函数接口。

模拟实现代码如下:
namespace NIC //防止命名冲突
{template<class T, class Container = std::deque<T>>class stack{public://元素入栈void push(const T& x){_con.push_back(x);}//元素出栈void pop(){_con.pop_back();}//获取栈顶元素T& top(){return _con.back();}const T& top() const{return _con.back();}//获取栈中有效元素个数size_t size() const{return _con.size();}//判断栈是否为空bool empty() const{return _con.empty();}//交换两个栈中的数据void swap(stack<T, Container>& st){_con.swap(st._con);}private:Container _con;};
}
测试一下:

queue的模拟实现:
同样的方式,我们也是通过调用所指定容器的各个成员函数来实现queue的。

模拟实现代码如下:
namespace NICO //防止命名冲突
{template<class T, class Container = std::deque<T>>class queue{public://队尾入队列void push(const T& x){_con.push_back(x);}//队头出队列void pop(){_con.pop_front();}//获取队头元素T& front(){return _con.front();}const T& front() const{return _con.front();}//获取队尾元素T& back(){return _con.back();}const T& back() const{return _con.back();}//获取队列中有效元素个数size_t size() const{return _con.size();}//判断队列是否为空bool empty() const{return _con.empty();}//交换两个队列中的数据void swap(queue<T, Container>& q){_con.swap(q._con);}private:Container _con;};
}
测试一下:

相关文章:
【C++初阶】STL详解(七)Stack与Queue的模拟实现
本专栏内容为:C学习专栏,分为初阶和进阶两部分。 通过本专栏的深入学习,你可以了解并掌握C。 💓博主csdn个人主页:小小unicorn ⏩专栏分类:C 🚚代码仓库:小小unicorn的代码仓库&…...
校园报修抢修小程序系统开发 物业小区报修预约上门维修工单系统
开发的功能模块有: 1.报修工单提交:学生、教职员工等可以使用小程序提交报修请求。这通常包括选择报修的问题类型(如水漏、电器故障、照明问题等),地点,报修联系人,联系电话等,并提供…...
【Android】Hilt比Android好在哪里
Hilt框架的功能和设计理念,和Dagger基本是完全一致的,Hilt也是完全在Dagger基础上进行开发的 但是Dagger的用法比较繁琐,Hilt主要是做了便用性上的改进,主要有以下点 提供常用Component,不用再为每个InjectTarget都创…...
计算方法 期末总结
思维导图 绪论 算法的性质: 有穷性、确切性、有输入输出、可行性 算法的描述方法: 自然语言、伪代码、流程图、N-S流程图 算法设计思想: 化大为小的缩减技术:二分法化难为易的校正技术:开方法化粗为精的松弛技术&a…...
【面试】jvm中堆是分配对象存储的唯一选择吗
目录 一、说明二、逃逸分析2.1 说明2.2 参数设置 一、说明 1.在《深入理解Java虚拟机》中关于Java堆内存有这样一段描述:随着JIT编译期的发展与逃逸分析技术逐渐成熟,栈上分配、标量替换优化技术将会导致一些微妙的变化,所有的对象都分配到堆上也渐渐变得…...
音视频同步笔记 - 以音频时间为基
音视频同步 - 以音频时间为基 上图介绍: 该图是以音频的时间为基,对视频播放时间的延迟控制方案,只调整视频的播放延时。delayTime是视频播放的延迟时间,初始值是1 / FPS * 1000 (ms),如果FPS为25帧率,初始…...
JavaScript 原始数据类型和对应的对象类型(内置对象)之间的关系
JavaScript 原始数据类型和对应的对象类型(内置对象)之间的关系 JavaScript 的原始(primitive)数据类型包括包括数字(Number)、字符串(String)、布尔值(Boolean…...
报错For debugging consider passing CUDA_LAUNCH_BLOCKING=1.
.报错For debugging consider passing CUDA_LAUNCH_BLOCKING1. /aten/src/ATen/native/cuda/NLLLoss2d.cu:103: nll_loss2d_forward_kernel: block: [29,0,0], thread: [707,0,0] Assertion t > 0 && t < n_classes failed. 报错信息如下: ./aten/…...
whisper使用方法
看这个 github https://github.com/Purfview/whisper-standalone-win/tags下载 视频提取音频 ffmpeg -i 222.mp4 -vn -b:a 128k -c:a mp3 output.mp3截取4秒后的音频 ffmpeg -i output.mp3 -ss 4 -c copy output2.mp3使用 whisper-faster.exe 生成字幕 whisper-faster.exe …...
通过easyexcel实现数据导入功能
上一篇文章通过easyexcel导出数据到excel表格已经实现了简单的数据导出功能,这篇文章也介绍一下怎么通过easyexcel从excel表格中导入数据。 目录 一、前端代码 index.html index.js 二、后端代码 controller service SongServiceImpl 三、功能预览 四、后端…...
Springboot_文件下载功能(前端后端)
遇到的问题: 文件下载后文件一直被破坏,无法正常打开文件名乱码,如图 刚开始一直在纠结,是不是后端没有写对,然后导致下载不能使用 后来搜索了一些资料,发现后端没什么问题 然后就开始找到其他项目对比…...
Vue框架学习笔记——v-bind数据单向绑定和v-model数据双向绑定
文章目录 v-bind,数据单向绑定简写形态(省略v-bind,只留冒号)示例一(将输入框数据改为:哈哈哈哈哈):实例二(将Vue实例中的name改为字符串:"单向绑定&quo…...
将对象转成URL参数
背景 有的时候前端跳转到其他平台的页面需要携带额外的参数,需要将对象转成用 & 连接的字符串拼接在路径后面。 实现方法...
【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法
文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中,传感器和控制器产生大量周…...
超级武器!深入LoadRunner性能测试流程及极速分析结果!
性能测试目的 1 什么是性能测试? 性能测试是通过性能的测试工具模拟多种正常、峰值以及异常负载条件来对系统的各项性能指标进行测试。 负载测试和压力测试都属于性能测试,两者可以结合进行。通过负载测试,确定在各种工作负载下系统的性能࿰…...
解决requests库进行爬虫ip请求时遇到的错误的方法
目录 一、超时错误 二、连接错误 三、拒绝服务错误 四、内容编码错误 五、HTTP错误 在利用requests库进行网络爬虫的IP请求时,我们可能会遇到各种错误,如超时、连接错误、拒绝服务等等。这些错误通常是由目标网站的限制、网络问题或我们的爬虫代码中…...
大语言模型领域的重要术语解释
前言 本人对人工智能非常感兴趣,目前是一名初学者,在研究大语言模型的一些内容。很多模型都是用英文提出的,其中也包括很多概念,有些概念的中文翻译和其想表达的意思不完全一样,所以在这里,想更加精准地帮…...
无需公网IP,使用内网穿透实现公网访问本地OpenWRT管理界面
文章目录 1.openWRT安装cpolar2.配置远程访问地址3.固定公网地址 简单几步实现在公网环境下远程访问openWRT web 管理界面,使用cpolar内网穿透创建安全隧道映射openWRT web 界面面板443端口,无需公网IP,无需设置路由器。 1.openWRT安装cpola…...
利用 docker 实现JMeter分布式压测
为什么需要分布式? 在工作中经常需要对一些关键接口做高QPS的压测,JMeter是由Java 语言开发,没创建一个线程(虚拟用户),JVM默认会为每个线程分配1M的堆栈内存空间。受限于单台试压机的配置很难实现太高的并…...
Sentinel 分布式系统
Sentinel 是一种分布式系统的流量防卫兵和熔断器,由阿里巴巴开发并开源。它的主要目标是保护分布式系统中的稳定性和可用性,防止因高并发或异常流量而导致的系统崩溃。下面是 Sentinel 的原理和使用教程的概要: Sentinel 的原理:…...
AI智能体开发框架agent-pack-n-go:开箱即用的快速构建与部署指南
1. 项目概述:一个开箱即用的智能体开发与部署框架最近在探索AI智能体(Agent)的落地应用时,发现了一个痛点:从构思一个智能体到真正把它跑起来,中间隔着“十万八千里”。你需要考虑框架选型、环境配置、工具…...
新概念英语第二册42_Not very musical
Lesson 42: Not very musical 不太懂音乐Key words and expressions musical 精通音乐的Delhi /ˈdeli/德里(印度城市)square 广场snake charmer 耍蛇人pipe (吹奏的)管乐器tune…...
ARM C库线程安全与可重入函数实现解析
1. ARM C库中的线程安全与可重入函数实现在嵌入式系统开发中,多线程编程已成为提升系统性能的必备技能。但随之而来的线程安全问题却让许多开发者头疼不已——数据竞争、死锁、不可预期的行为,这些都可能让精心设计的系统崩溃。ARM C库作为嵌入式开发的基…...
制造业成本困局:大宗材料价格波动如何破局
在制造业的日常运营中,原材料成本始终是绕不开的核心话题。尤其是铜、铝、锡、银等大宗材料,其价格波动如同过山车,让企业采购部门时刻紧绷神经。每天数万甚至数十万的隐性成本风险,像一把悬在头顶的达摩克利斯之剑,让…...
怎么删除MongoDB中不再使用的账号
db.dropUser()用于删除指定数据库中的用户,需先use目标库,用户名区分大小写,返回true表示成功,false通常因用户不存在或库不匹配。用 db.dropUser() 删除指定账号MongoDB 没有“禁用账号”概念,删就完了。核心操作就是…...
别再为CCD黑屏发愁了!手把手教你用Keyence视觉系统搞定新相机调试(附参数避坑清单)
工业视觉系统新相机调试实战指南:从黑屏到高清成像的完整解决方案 第一次给产线换上新的CCD相机时,那种期待和紧张感至今记忆犹新。作为产线视觉检测系统的"眼睛",新相机的表现直接关系到整条生产线的质量控制水平。但现实往往比理…...
【技术干货】打破协议壁垒:基于 GB28181/RTSP 的 AI 视频管理平台架构解析(附源码交付与边缘计算实践)
引言:安防开发的“第一公里”梦魇 作为一名在安防行业摸爬滚打十年的架构师,我深知开发者在面对多厂商、异构协议时的绝望。 海康的私有 SDK、大华的码流封装、宇视的信令差异,加上 GB28181 国标协议那复杂的 140 页文档…… 每一个新项目的…...
【优化调度】含氢气氨气综合能源系统优化调度【含Matlab源码 15394期】
💥💥💥💥💥💥💥💥💞💞💞💞💞💞💞💞💞Matlab武动乾坤博客之家💞…...
底层算法逆向揭秘:哪些降重软件可以同时降低查重率和AIGC疑似率?2026高效论文降重方案全解析
【CSDN独家硬核长文 / 年度置顶专栏】 博主身份:CSDN百大实力榜博主 / AI安全与大语言模型(LLM)风控研究员 / 硕博避坑指南星推官 版权声明:本文系2026年毕业压测季的最真实黑盒施压数据,未经授权严禁搬运。这是一场为了保住各位毕业双证的“…...
别只看理论!用Wireshark抓包实战解析5G信令流程(附大唐杯真题分析)
别只看理论!用Wireshark抓包实战解析5G信令流程(附大唐杯真题分析) 在5G技术快速发展的今天,理解其底层信令交互机制已成为通信工程师和学生的必备技能。然而,传统的理论学习往往让人陷入"知其然而不知其所以然&q…...
