【c++】【STL】queue详解

目录

queue的作用

queue是stl库提供的一种容器适配器,也就是我们数据结构中学到的队列,是非常常用的数据结构,特点是遵循LILO(last in last out,也就是后进后出)原则。

什么是容器适配器

stl中提供的类很多都叫容器,但有一些叫做容器适配器,容器适配器到底是啥呢?我们不妨先抛掉容器这两个字,先来谈谈适配器,适配器是软件设计之中的一种概念,即基于原有的接口设计适配出用户想要的接口,是一种设计模式,适配器这种设计模式提升了代码复用性以及系统扩展性,降低了代码的耦合度,是一种优秀的设计模式。那么对于容器适配器来说,就是利用已有的容器进行各种操作封装出新的类,这就叫容器适配器。

queue的接口

构造函数

cpp 复制代码
explicit queue (const container_type& ctnr = container_type());

一般来说不用给参数,直接调用默认构造就行。

empty

cpp 复制代码
bool empty() const;

队列的判空。

size

cpp 复制代码
size_type size() const;

返回队列的元素数。

front

cpp 复制代码
      value_type& front();
const value_type& front() const;

返回队列的第一个元素。

back

cpp 复制代码
      value_type& back();
const value_type& back() const;

返回队列的最后一个元素。

queue类的实现

cpp 复制代码
#define _CRT_SECURE_NO_WARNINGS 1

#include<iostream>

#include<deque>

using namespace std;

namespace jiunian
{
	template<class T, class container = deque<T>>
	class queue
	{
	public:
		typedef queue<T, container> Self;

		//queue()
		//{
		//}

		//queue(Self& x):
		//	con(x.con)
		//{
		//}

		//~queue()
		//{
		//}

		bool empty() const
		{
			return con.empty();
		}

		size_t size() const
		{
			return con.size();
		}

		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 push(const T& val)
		{
			con.push_back(val);
		}

		void pop()
		{
			con.pop_front();
		}

		void swap(Self& x)
		{
			con.swap(x.con);
		}

		Self operator=(Self& x)
		{
			con = x.con;
			return *this;
		}
	private:
		container con;
	};
}

queue作为一个容器适配器,实现起来相比其他容器明显简单了不少,因为其作为容器适配器只需要对其他容器的接口进行封装就行,不需要自己造轮子。实现过程一看就懂,不做过多赘述。

相关推荐
3824278273 分钟前
python3网络爬虫开发实战 第2版:并发限制
开发语言·爬虫·python
ss27310 分钟前
线程池配置-七大关键参数
java·开发语言
HeDongDong-11 分钟前
Kotlin Lambda 表达式详解
android·开发语言·kotlin
最后一个bug12 分钟前
浅显易懂的讲解MMU是如何使用4级页表把虚拟地址转化为物理地址的~
linux·服务器·开发语言·系统架构·计算机外设
superman超哥13 分钟前
Rust 函数定义与参数传递:所有权系统下的设计艺术
开发语言·rust·设计艺术·rust函数定义·rust参数传递
2301_7890156214 分钟前
C++:set/multiset和map/multimap文档详细解析
c语言·开发语言·c++·vscode·排序算法·set·map
“抚琴”的人15 分钟前
C#上位机策略模式
开发语言·c#·策略模式
CoderCodingNo15 分钟前
【GESP】C++五级真题(数论-素数思想考点) luogu-P10720 [GESP202406 五级] 小杨的幸运数字
开发语言·c++·算法
zmzb010315 分钟前
C++课后习题训练记录Day59
开发语言·c++
黎雁·泠崖16 分钟前
C 语言文件操作进阶:格式化读写 + 二进制读写 + 随机读写进阶全解
c语言·开发语言