STL之容器适配器stack的实现框架
说明:本文仅供学习交流,转载请标明出处,欢迎转载!
一提到适配器(adapter)。我们就想到了早期用电话线上网所用的调制解调器,俗称“猫”。“猫”的作用是实现数模转化和模数转化,在client,它能够将电话的模拟信息转化为我们计算机能够接收的数字信息,所以猫相当于一个转换器。再举个更加好理解的样例来说明"适配器“的含义。相信在我们每一个人的家里都有插排,如果就这么一种情况。如今我们家里的墙壁上仅仅有一个三角的插口,而我们的电视却是两个口,怎么办?毫无疑问。我们能够接一个新的插排,该插排至少有两个孔,一个是用于连接墙壁上的三角的插口,一个则是提供给电视剧用的两口的插口。这样,我们就能够将新增加的中间用于转换的插排是一个适配器。
从上面的样例我们可以非常easy的得出:适配器可以对原始事物进行一次封装与修饰。并提供第二种接口。该接口可以更好地满足用户的需求。具有一定的专用性。
这样。我们就行介绍下stack这一容器适配器了。
之前我们已经介绍过三种主要的顺序容器,各自是vector、list和deque,这三种顺序容器的设计都会设计到迭代器的概念。STL要求不论什么一种容器都必须内置一个迭代器,假设连迭代器都没有内置,就谈不上”容器“的定义了。所以。stack仅仅是一个容器适配器,并非一个容器,由于stack不提供迭代器,所以在元素不弹出的前提下不可以遍历内部全部的元素。
学习过”数据结构“的人都知道栈,栈是一种后进先出或者说先进后出的数据结构,一个栈的插入和删除操和取值都仅仅能在栈顶进行。依据栈的性质,栈顶元素必定是最后一个进入的元素。依据这点,我们可以非常easy地得出一个结论:不论什么提供末端插入(push_back函数)、删除(pop_back函数)、訪问(back函数)都可以被stack容器封装与修饰。这里的封装指的是通过stack对象,你不能直接訪问被封装的底层容器了,所谓的修饰指的是stack在对底层容器做封装的同一时候。还提供了必要的接口。以满足用户的须要。
我们将被适配器封装的底层容器称为基础容器。
在我们所学过的顺序容器中,仅仅要能够提供末端的插入、删除和訪问操作。都能够作为stack适配器的基础容器。所以vector、list和deque都能够作为stack的基础容器,而stack默认的基础容器为deque容器。
对于一个stack,我们通常须要提供这几个接口函数:
(1)获取栈内当前元素的个数:size_type size();
(2)取栈顶元素(但并不弹出):T top();
(3)入栈:void push(const T &t);
(4)出栈:void pop();
(5)推断是否栈空:bool empty()。
假设想使用STL定义的容器适配器stack,须要引用stack头文件,即#include<stack>
以下给出stack适配器的实现代码:
#include<iostream>
#include<deque>
using namespace std;
/*******************stack适配器的定义**************/
template<class T,class Sequence=deque<T> >
class stack
{
friend bool operator==(const stack&,const stack&);//friend函数是全局函数,不受private的限制
friend bool operator<(const stack&,const stack&);//类内声明。类外定义,定义是不加friend
public:
typedef typename Sequence::value_type value_type;//typename类型声明,元素类型
typedef typename Sequence::size_type size_type;//大小类型
typedef typename Sequence::reference reference;//引用声明
typedef typename Sequence::const_reference const_reference;//常引用声明
protected:
Sequence c;//基础的底层容器
public:
bool empty()const;//是否为空
size_type size()const;//大小
reference top();//取顶部元素
const_reference top()const;
void push(const value_type &x);//压栈
void pop();//出栈
};
/******************各个函数接口的类外实现**********************/
template<class T,class Sequence>
bool operator==(const stack<T,Sequence> &x, const stack<T,Sequence> &y)//推断两个适配器是否相等
{
return x.c==y.c;
} template<class T,class Sequence>
bool operator<(const stack<T,Sequence>& x,const stack<T,Sequence>& y)//推断适配器x是否小于适配器y
{
return x.c<y.c;
} template<class T,class Sequence>
bool stack<T,Sequence>::empty()const//常成员函数类外定义须要加constkeyword
{
return c.empty();
} template<class T,class Sequence>//类外无需加默认形參
//假设写成size_type stack<T,Sequence>::size()const是错误的,由于size_type是在类内定义的,且typename最好也加上
typename stack<T,Sequence>::size_type stack<T,Sequence>::size()const
{
return c.size();
} template<class T,class Sequence>
typename stack<T,Sequence>::reference stack<T,Sequence>::top()//底层实现是返回最后一个容器的元素
{
return c.back();
} template<class T,class Sequence>
typename stack<T,Sequence>::const_reference stack<T,Sequence>::top()const//top函数的重载
{
return c.pop_back();
} template<class T,class Sequence>
void stack<T,Sequence>::push(const value_type & x)//底层实现是向基础容器的尾部加入元素
{
c.push_back(x);
} template<class T,class Sequence>
void stack<T,Sequence>::pop()//底层实现是将基础容器的尾部元素弹出
{
c.pop_back();
}
參考资料:
[1]《STL源代码剖析 侯捷》
[2]《C++ primer 第4版》
STL之容器适配器stack的实现框架的更多相关文章
- STL之容器适配器queue的实现框架
说明:本文仅供学习交流,转载请标明出处,欢迎转载! 上篇文章STL之容器适配器stack的实现框架已经介绍了STL是怎样借助基础容器实现一种经常使用的数据结构stack (栈),本文介绍下第二种STL ...
- 初步STL该容器适配器
容器适配器 特点 容器一定的顺序来实现(让现有的以集装箱堆放/式工作) 分类 1) stack: 头文件 <stack> • 栈 -- 后进先出 2) queue: 头文件 <que ...
- STL容器适配器 stack, queue
stack是一种后进先出(last in first out)的数据结构.它只有一个出口,如图所示.stack允许新增元素,删除元素,取得最顶端元素.但除了最顶端外,没有其他任何地方可以存储stack ...
- 容器适配器————stack
只能访问 stack 顶部的元素:只有在移除 stack 顶部的元素后,才能访问下方的元素. 堆栈操作 top():返回一个栈顶元素的引用,类型为 T&.如果栈为空,返回值未定义. push( ...
- STL之容器适配器priority_queue
priority_queue(优先队列)是一个拥有权值观念的queue,它允许加入新元素,删除旧元素,审视元素值等功能.由于这是一个queue,所以只允许在底端加入元素,并从顶端取出元素, 除此之外别 ...
- 容器适配器(stack、 queue 、priority_queue)源码浅析与使用示例
一.容器适配器 stack queue priority_queue stack.queue.priority_queue 都不支持任一种迭代器,它们都是容器适配器类型,stack是用vector/d ...
- C++顺序性容器、关联性容器与容器适配器
什么是容器 首先,我们必须理解一下什么是容器,在C++ 中容器被定义为:在数据存储上,有一种对象类型,它可以持有其它对象或指向其它对像的指针,这种对象类型就叫做容器.很简单,容器就是保存其它对象的对象 ...
- C++ 容器:顺序性容器、关联式容器和容器适配器
什么是容器 首先,我们必须理解一下什么是容器,在C++ 中容器被定义为:在数据存储上,有一种对象类型,它可以持有其它对象或指向其它对像的指针,这种对象类型就叫做容器.很简单,容器就是保存其它对象的对象 ...
- STL标准库-容器适配器
技术在于交流.沟通,本文为博主原创文章转载请注明出处并保持作品的完整性 上一节介绍了仿函数适配器,这节主要介绍容器适配器和迭代器适配器的概念,其实容器适配器和迭代器其适配器就是封装了一些其他class ...
随机推荐
- 开发中关于Git那些事
如果你想精通Git,直接到 Git官网 把这本ProGit掌握已足以Pro Git 此文主要介绍一切开发中常用的git命令和一些配置技巧(诸如git别名配置,log打印技巧,版本回退以及分支管理等). ...
- linux 安装 Elasticsearch5.6.x 详细步骤以及问题解决方案
在网上有很多那种ES步骤和问题的解决 方案的,不过没有一个详细的整合,和问题的梳理:我就想着闲暇之余,来记录一下自己安装的过程以及碰到的问题和心得:有什么不对的和问题希望及时拍砖. 第一步:环境 li ...
- JavaWeb笔记一、Servlet 详解
一.创建一个 Servlet 简单实现类 1.创建一个 HelloServlet 类(测试 Servlet 接口方法) 1 //创建一个 HelloServlet 类并实现 Servlet 接口 2 ...
- 解决autocad闪退
1.进入注册表,regedit 2.找到ROOT\installer\Products ,找到以7D2F开头的键值,这里有两个都得删除 3.删除programdata目录下的AutoDesk目录,及f ...
- ajax事件请求
首先,ajax是什么? ajax是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术. ajax是一种用于创建的快速动态网页的技术. 当async:true时,表示异步执行ajax代码:当as ...
- C#获取指定月指定周的日期范围
); MessageBox.Show(end.ToShortDateString());
- [转载] Java并发编程:Lock
转载自http://www.cnblogs.com/dolphin0520/p/3923167.html 以下是本文目录大纲: 一.synchronized的缺陷 二.java.util.concur ...
- 25个Java机器学习工具和库
本列表总结了25个Java机器学习工具&库: 1. Weka集成了数据挖掘工作的机器学习算法.这些算法可以直接应用于一个数据集上或者你可以自己编写代码来调用.Weka包括一系列的工具,如数据预 ...
- day01_HTML
今日任务 网站信息页面案例 网站图片信息页面案例 网站友情链接页面案例 网站首页案例 网站后台页面案例 教学目标 了解什么是标记语言 了解HTML的框架标签 掌握HTML的主要标签(字体,图片,列表, ...
- pku夏令营面试
北大面试题目: 一.内存交换 内存交换(对换)的基本思想是,把处于等待状态(或在CPU调度原则下被剥夺运行权利) 的程序从内存移到辅存,把内存空间腾出来,这一过程又叫换出:把准备好竞争CPU运行的程序 ...