当前位置: 首页 > news >正文

c++的stl库中stack的解析和模拟实现

目录

1.stack的介绍和使用

1.1stack的介绍

1.2stack的使用

 2.stack的模拟实现


1.stack的介绍和使用

1.1stack的介绍

1. stack 是一种容器适配器,专门用在具有后进先出操作的上下文环境中,其删除只能从容器的一端进行元素的插入与提取操作。
2. stack 是作为容器适配器被实现的,容器适配器即是对特定类封装作为其底层的容器,并提供一组特定的成员函数来访问其元素,将特定类作为其底层的,元素特定容器的尾部( 即栈顶 ) 被压入和弹出。
3. stack 的底层容器可以是任何标准的容器类模板或者一些其他特定的容器类,这些容器类应该支持以下操作:
empty :判空操作
back :获取尾部元素操作
push_back :尾部插入元素操作
pop_back :尾部删除元素操作
4. 标准容器 vector deque list 均符合这些需求,默认情况下,如果没有为 stack 指定特定的底层容器,默认情况下使用deque

1.2stack的使用

 2.stack的模拟实现

        从栈的接口中可以看出,栈实际是一种特殊的vector ,因此使用 vector 完全可以模拟实现 stack
namespace fish
{template<class T, class Con = deque<T>>class stack{public:void push(const T& x) {_c.push_back(x);}void pop() {_c.pop_back();}T& top() {return *(--_c.end());}const T& top()const {return *(--_c.end());}size_t size()const {return _c.size();}bool empty()const {return _c.empty();}private:Con _c;};
};

        上面我自己写的模拟实现地源码包括了stl库中stack的主要接口,有助于进一步地理解stack类。

http://www.lryc.cn/news/515054.html

相关文章:

  • C语言——字符函数和内存函数
  • 查询docker overlay2文件夹下的 c7ffc13c49xxx是哪一个容器使用的
  • Golang的容器编排实践
  • 【51项目】51单片机自制小霸王游戏机
  • ArkTs之NAPI学习
  • 【数据库初阶】MySQL中表的约束(上)
  • 173. 矩阵距离 acwing -多路BFS
  • Linux下部署Redis集群 - 一主二从三哨兵模式
  • 实战设计模式之建造者模式
  • 活动预告 | Microsoft Azure 在线技术公开课:使用 Azure OpenAI 服务构建生成式应用
  • ubuntu安装firefox
  • 计算机网络原理(谢希仁第八版)第4章课后习题答案
  • RabbitMQ-基本使用
  • 从零开始学架构——互联网架构的演进
  • python +tkinter绘制彩虹和云朵
  • 重新整理机器学习和神经网络框架
  • TypyScript从入门到精通
  • 【MATLAB】绘制投资组合的有效前沿
  • matlab时频分析库
  • GBase 8s 数据库备份还原
  • C++模板相关概念汇总
  • MYSQL------sql基础
  • React Router 用法概览
  • 网络安全之高防IP的实时监控精准防护
  • 2024年中国新能源汽车用车发展怎么样 PaperGPT(二)
  • LINUXC 时间相关操作
  • 网络游戏之害
  • SpringMVC的消息转换器
  • Chrome 浏览器下载安装教程,保姆级教程
  • ElasticSearch系列(一)