1、思路讲解

stack集合类是一个简单的堆栈的实现。

这里有两个模板参数,T和size,T用于指定堆栈中的元素类型,my_size用于表示堆栈中项数的最大值。

类中添加方法isempty、isfull、push、pop。

2、涉及解说

  对于很久没用C++写代码的我,对于模板类很陌生了,所以首先简单介绍下模板类。

(1)用途:有那么一部分类,用途和方法是一样的,只是涉及的一些参数不同(如参数类型),这个时候引入了类模板来解决这个问题;有了类模板,我们在声明类的时候对于参数的不确定,我们先不给于具体的绑定,等到实例化的时候再指明具体的性质。

  例如函数模板的swap函数,有的想实现int型的两个变量值交换,有的想实现两个string型变量值的交换;有了函数模板,我们只需要写一个函数就可以解决不同需求:

 #include<iostream>
#include<string>
using namespace std; template<typename T>
void mySwap(T &a,T &b)
{
T temp;
temp = a;
a = b;
b = temp;
} int main()
{
//prepare parameter
int a1=,b1=;
string a2="Christal",b2="Carl";
//swap two int parameter
cout<<"a1= "<<a1<<" b1= "<<b1<<endl;
mySwap<int>(a1,b1);
cout<<"a1= "<<a1<<" b1= "<<b1<<endl;
//swap two string parameter
cout<<endl<<"a2= "<<a2<<" b2= "<<b2<<endl;
mySwap<string>(a2,b2);
cout<<"a2= "<<a2<<" b2= "<<b2<<endl; return ;
}

  输出结果:

(2)用法:

 template<class 模板参数表>
class 类名
{
//类定义
};
int main()
{
类名<参数类型> 对象名;
}

  其中,template是类模板声明的关键字;模板参数可以只有一个,也可以有多个;参数可以是类型参数也可以是非类型参数;类型参数用关键字class或typename;非类型参数由一个普通参数构成,代表模板定义中的一个常量。

 template<class type,int width> class Hey;
//type为类型参数,width为非类型参数

(3)类模板的实例化

  type、width是形参,同类型的实参值被提供给形参;指定的每个不同类型的值都创建一个新类。

 template<class type,int width>
class Hey
{
private:
type str;
int maxwidth;
public:
Hey():maxwidth(width){}
};

  type被指定为string,width被指定为10,创建一个类;

1 Hey<string,> say1;

  type被指定为char,width被指定为1,创建一个类;

1 Hey<char,> say2;

3、思路实现

 #include<iostream>
#include<string>
using namespace std; template<class T,int my_size> //T:type , my_size:size
class myStack
{
private:
int top; //top pointer
T items[my_size]; //stack array
const int max_size; //array size
public:
myStack():max_size(my_size),top(-){}
bool isempty();
bool isfull();
void push(const T temp);
T pop();
};
template<class T,int my_size>
bool myStack<T,my_size>::isempty()
{
if(top == -)
return true;
else
return false;
}
template<class T,int my_size>
bool myStack<T,my_size>::isfull()
{
if(top == max_size-)
return true;
else
return false;
}
template<class T,int my_size>
void myStack<T,my_size>::push(const T temp)
{
if(!isfull())
{
items[++top] = temp;
}
}
template<class T,int my_size>
T myStack<T,my_size>::pop()
{
if(!isempty())
{
return items[top--];
}
} int main()
{
//prepare parameter
int i=;
string x;
string temp[] = {"Christal","Carl","Jerry","Belle","Sea","vinky","Rita","Nila"};
//initialize stack
myStack<string,> s;
//push someone
while(!s.isfull())
{
s.push(temp[i]);
cout<<"push one person"<<endl;
i++;
}
cout<<endl<<"stack is full"<<endl<<endl;
//pop someone
while(!s.isempty())
{
x = s.pop();
cout<<x<<" is pop"<<endl;
}
cout<<endl<<"stack is empty"<<endl; return ;
}

  输出检验:

实现一个栈类,类似STL中的栈的更多相关文章

  1. <软件架构与设计模式>侯捷老师关于Adapter类在STL中的深入解析和模式探讨

    题外话:侯捷老师难得一年就来上九堂课就要会宝岛,特此留念签名赠语及合照以自勉.  学海无涯,为勤是岸 <正文开始> 昨天晚上连上了3个小时的大课探究单单讲了Adapter一个类,幸运的是本 ...

  2. STL之stack栈

    栈(statck)这种数据结构在计算机中是相当出名的.栈中的数据是先进后出的(First In Last Out, FILO).栈只有一个出口,允许新增元素(只能在栈顶上增加).移出元素(只能移出栈顶 ...

  3. STL中的stack(堆栈)

    转载:http://blog.csdn.net/morewindows/article/details/6950881 栈(statck)这种数据结构在计算机中是相当出名的.栈中的数据是先进后出的(F ...

  4. STL中一些函数的应用

    1.nth_element():找到第几大的数.用法:nth_element(a,a+k,a+n),返回一个数组a中第k大的数,时间复杂度比较小,头文件#include <algorithm&g ...

  5. Java中的栈,堆,方法区和常量池

    要说Java中的栈,堆,方法区和常量池就要提到HotSpot,HotSpot是Sun JDK 和 Open JDK中所带的虚拟机. (Sun JDK 和 Open JDK除了注释不同,代码实现基本上是 ...

  6. C++中如何设计一个类只能在堆或者栈上创建对象,面试题

    设计一个类,该类只能在堆上创建对象 将类的构造函数私有,拷贝构造声明成私有.防止别人调用拷贝在栈上生成对象. 提供一个静态的成员函数,在该静态成员函数中完成堆对象的创建 注意 在堆和栈上创建对象都会调 ...

  7. 怎样从一个DLL中导出一个C++类

    原文作者:Alex Blekhman    翻译:朱金灿 原文来源: http://www.codeproject.com/KB/cpp/howto_export_cpp_classes.aspx 译 ...

  8. 智能指针类模板(上)——STL中的智能指针

    智能指针类模板智能指针本质上就是一个对象,它可以像原生指针那样来使用. 智能指针的意义-现代C++开发库中最重要的类模板之一-C++中自动内存管理的主要手段-能够在很大程度上避开内存相关的问题 1.内 ...

  9. 一个java源文件中为什么只能有一个public类。

    我们都遇到过一个源文件中有多个java类,但当第一个类使用public修饰时,如果下面还有类使用public修饰,会报错.也就是是说一个java源文件最多只能有一个public类. 当有一个publi ...

随机推荐

  1. opcache开启前后性能对比

    opcache PHP新的字节码缓存扩展 字节码缓存组件 Zend Optimizer+ 现在更改名字为 Zend opcache了.且在php 5.5版本后,会集成到php的官方组件中,也就没有必要 ...

  2. C语言集成开发环境vs2017的使用技巧之修改快捷键

    首先这里是说编辑C语言内容,其次开发环境是vs2017(全称:visual studio 2017).像这个开发环境体积大,但你安装的时候不要安装到C盘,然后安装的时候选择模块,比如你不开发网站,就先 ...

  3. 基于FPGA的均值滤波算法的实现

    前面实现了基于FPGA的彩色图像转灰度处理,减小了图像的体积,但是其中还是存在许多噪声,会影响图像的边缘检测,所以这一篇就要消除这些噪声,基于灰度图像进行图像的滤波处理,为图像的边缘检测做好夯实基础. ...

  4. MyBatis源码分析之环境准备篇

    前言 之前一段时间写了[Spring源码分析]系列的文章,感觉对Spring的原理及使用各方面都掌握了不少,趁热打铁,开始下一个系列的文章[MyBatis源码分析],在[MyBatis源码分析]文章的 ...

  5. IntelliJ IDEA提示:Error during artifact deployment. See server log for details.

    IntelliJ IDEA-2017.1.1 tomcat-8.5.13   问题:在IntelliJ IDEA中使用tomcat部署web app时,提示:Error during artifact ...

  6. java面试笔试大汇总

    java面试笔试题大汇总5 JAVA相关基础知识 1.面向对象的特征有哪些方面 1.抽象:2.继承:3.封装:4. 多态性: 2.String是最基本的数据类型吗? 基本数据类型包括byte.int. ...

  7. nginx之 nginx-1.9.7 + tomcat-8.5.15 反向代理+应用负载均衡 安装配置

    环境说明:nginx 反向代理服务器 ip 为: 10.219.24.26tomcat1 应用服务器 ip 为: 10.219.24.21tomcat3 应用服务器 ip 为: 10.219.24.2 ...

  8. 锁和监视器之间的区别 – Java并发

    在面试中你可能遇到过这样的问题:锁(lock)和监视器(monitor)有什么区别? 嗯,要回答这个问题,你必须深入理解Java的多线程底层是如何工作的. 简短的答案是,锁为实现监视器提供必要的支持. ...

  9. 利用Jsoup包爬取网站内容

    一 Jsoup包 下载链接:http://download.csdn.net/detail/u014000832/7994245 二 爬取搜狐新闻网站标题等内容 package com.test1; ...

  10. 初玩RAC

    之前因为项目的原因以及ReactiveCocoa框架导入到项目老是报错的原因,导致我这边一直没有能好好的将ReactiveCocoa运行起来,最近看了Hank老师的视频,而且项目中我们使用的就是OC, ...