187-C++模板编程(类模板,模板顺序栈Stack实现)

类模板

模板类实现顺序栈Stack

类模板 => 实例化 => 模板类

#include <iostream>
using namespace std;

//类模板
template<typename T>
class SeqStack	//模板名称+类型参数列表 = 类名称
{
public:
	//构造和析构函数名不用加<T>,其它出现模板的地方都加上类型参数列表
	SeqStack(int size = 10)
		: _pstack(new T[size])
		, _top(0)
		, _size(size)
	{}

	~SeqStack()
	{
		delete[]_pstack;
		_pstack = nullptr;
	}

	//重写 拷贝构造
	SeqStack(const SeqStack<T>& stack)
		:_top(stack._top)
		, _size(stack._size)
	{
		_pstack = new T[_size];
		//不要用memcopy进行拷贝
		for (int i = 0; i < _top; ++i)
		{
			_pstack[i] = stack._pstack[i];
		}
	}

	//重写 赋值重载
	SeqStack<T>& operator=(const SeqStack<T>& stack)
	{
		//防止自赋值
		if (this == &stack)
			return *this;

		delete[]_pstack;

		_top = stack._top;
		_size = stack._size;
		_pstack = new T[_size];
		//不要用memcopy进行拷贝,如果类型是个对象,会出现浅拷贝
		for (int i = 0; i < _top; ++i)
		{
			_pstack[i] = stack._pstack[i];
		}

		return *this;
	}

	void push(const T& val);//入栈操作,在类外实现

	void pop()//出栈操作
	{
		if (empty())
			return;
		--_top;
	}

	T top()const//返回栈顶元素
	{
		if (empty())
			throw "stack is empty!";//抛异常也代表函数逻辑结束
		return _pstack[_top - 1];
	}
	bool full()const { return _top == _size; }//栈满
	bool empty()const { return _top == 0; }//栈空
private:
	T* _pstack;
	int _top;
	int _size;

	//顺序栈底层数组按2倍的方式扩容
	void expand()
	{
		T* ptmp = new T[_size * 2];
		for (int i = 0; i < _top; ++i)
		{
			ptmp[i] = _pstack[i];
		}
		delete[]_pstack;
		_pstack = ptmp;
		_size *= 2;
	}
};

template<typename T>//类外实现,还要再写这个哦,因为这个类模板作用域到{开始 }结束了 
void SeqStack<T>::push(const T& val)//入栈操作
{
	if (full())
		expand();
	_pstack[_top++] = val;
}

int main()
{
	//类模板的选择性实例化
	// 
	//实例化后 产生模板类 class SeqStack<int>{};
	SeqStack<int> s1;//编译器到达这个调用点,会把模板实例化一份专门处理int的类出来 
	//到这个点生成的模板类只有构造函数和析构函数,其他的方法等被对象调用了才被实例化出来 
	//减少编译器的工作 
	s1.push(20);
	s1.push(78);
	s1.push(32);
	s1.push(15);
	s1.pop();
	cout << s1.top() << endl;

	//SeqStack<> s2;	//template<typename T = int>

	return 0;
}

类模板还可以加默认的类型参数:
在这里插入图片描述

就可以这样去使用它
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

liufeng2023

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值