STL详解——stack以及queue的模拟实现

目录

容器适配器

stack的模拟实现

构造函数

其他功能

queue的模拟实现

由于stack以及queue的很多功能是基于其他容器的接口实现的,同时功能比较简单,所以我们在本文直接进行上述两个结构的模拟实现。

容器适配器

在上一篇文章中,我们只是简单提到了容器适配器,本文需要进行模拟实现就需要我们对容器适配器有一个深入的的理解,所以我们再详细地说说。

我们在查看官方的文档时,可以看到stack、queue被成为容器适配器,因为stack和queue只是对其他容器的接口进行了包装,STL中stack和queue默认使用deque容器,因为我们给了默认参数。

在stack和queue的类 模板声明当中我们就可以看到,它们的模板参数有两个,第一个是stack和queue当中所存储的元素类型,而另一个就是指定使用的容器类型。只不过当我们不指定使用何种容器的情况下,stack和queue都默认使用deque作为指定容器。

简单理解: 学过数据结构后我们都知道,stack和queue既可以使用顺序表实现,也可以使用链表实现。在这里我们若是定义一个stack,并指定使用vector容器,则定义出来的stack实际上就是对vector容器进行了包装。

stack的模拟实现

知道了容器适配器后,stack的模拟实现就显得相当简单,我们只需要调用所指定容器的各个成员函数即可实现stack的各个函数接口。

构造函数

我们前面学习类与对象时知道,当参数类型为自定义类型时,当我们没有写构造函数时,编译器会自动调用自定义类型的构造函数。那对于stack来说,我们就不需要自己写构造函数,我们使用的容器有自己的构造函数

其他功能

cpp 复制代码
namespace mine//我们自己的命名空间
{
	template<class T,class Container=std::vector<T>>//先使用vector试试水
	class stack
	{
	public:
        //功能实现都是比较简单的,应该很容易就能看懂了
        //我们使用的接口,最好是几个容器都有的接口,否则会导致编译错误
		bool empty() const
		{
			return _con.size()==0;
		}
		void push(const T& val)
		{
			_con.push_back(val);
		}
		void pop()
		{
			_con.pop_back();
		}
		size_t size() const
		{
			return _con.size();
		}
		T& top() const
		{
			return _con.back();
		}
		void swap(stack& st)
		{
			_con.swap(st._con);
		}
	private:
		Container _con;
	};

}

接下来给出deque的版本,其实是没什么区别的,这里只是让读者更好理解

cpp 复制代码
namespace mine
{
	template<class T, class Container = std::deque<T>>
	class stack
	{
	public:
		bool empty() const
		{
			return _con.size() == 0;
		}
		size_t size() const
		{
			return _con.size();
		}
		T& top()
		{
			return _con.back();
		}
		const T& top() const
		{
			return _con.back();
		}
		void push(const T& val)
		{
			_con.push_back(val);
		}
		void pop()
		{
			_con.pop_back();
		}
		void swap(stack& x)
		{
			_con.swap(x._con);
		}
	private:
		Container _con;
	};
}

queue的模拟实现

我们需要实现的功能

cpp 复制代码
namespace mine
{
	template<class T,class Container=std::deque<T>>
	class queue
	{
	public:
		bool empty() const
		{
			return _con.empty();
		}
		size_t size() const
		{
			return _con.size();
		}
		void push(const T& val)
		{
			_con.push_back(val);
		}
		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();
		}
		void swap(queue& que)
		{
			_con.swap(que._con);
		}
	private:
		Container _con;
	};
}
相关推荐
qq_2949405510 小时前
Python环境搭建
开发语言·python
zhaokuangkuang_10 小时前
Java学习
java·学习·算法
XMYX-011 小时前
40 - Go HTTP 客户端:从 http.Get 到高性能连接池
开发语言·http·golang
Daydream.V11 小时前
C++ 入门全攻略:从基础语法到核心特性
java·开发语言·c++
我是一颗柠檬11 小时前
【JDK8新特性】接口默认方法与静态方法Day8
java·开发语言·后端·intellij-idea
lulu121654407811 小时前
【开发者指南】Gemini 3.5开发入门:从API调用到Agent构建
java·开发语言·人工智能·python·ai编程
盲敲代码的阿豪11 小时前
Python 爬虫入门基础教程:从入门到实践
开发语言·爬虫·python
希冀12311 小时前
【CSS学习第十三篇】
前端·css·学习