当前位置: 首页 > news >正文

基于探索C++特殊容器类型:容器适配器+底层实现原理

前引:容器适配器(Container Adapters)是C++标准库提供的一些特殊容器,它们基于已有的顺序容器(如vector、deque、list)实现,但提供了不同的接口以满足特定的数据结构需求。容器适配器只提供特定操作,隐藏了底层容器的部分功能。主要有三种:stack(栈)、queue(队列)和priority_queue(优先队列) ,我们一起来看看吧!

目录

适配器介绍

三大容器适配器

特性讲解

stack的底层实现

类模板定义

入栈

出栈

获取栈顶元素

判断栈空

获取栈元素

效果展示

queue的底层实现

类模板定义

入队列

获取队头元素

获取队尾元素

出队列

获取队列元素个数

判断队空

效果展示


适配器介绍

容器适配器是C++标准库提供的特殊容器类型,它们基于现有顺序容器实现,但提供受限接口和特定行为。它们不是完整的容器,而是对底层容器的包装

三大容器适配器

(1)stack:默认底层容器为 deque,遵循后进先出

(2)queue:默认底层容器为 deque,遵循先进先出

(3)priority_queue:默认底层容器为 vector,优先级最高者先出

特性讲解

(2)在元素访问上受限:比如 stack 只能访问栈顶元素

                                          比如 queue 遵循先进先出,只能访问队头元素

(2)不支持迭代器的使用

(3)适用于特定的数据结构

stack的底层实现

我们上面已经说到 stack 的底层容器为 deque,虽然 deque 可以两端进出,因此需要我们封装

类模板定义

既然 stack 是通过 底层封装 deque 实现的,而我们实际在使用 stack 中,只需要一个类模板参数,因此我们推出如果要使用 deque 作为底层,应该需要缺省参数

template<class T,class contain=std::deque<T>>
class stack
{
public://实现private:contain x;
};

这里的 contain 作为类模板参数应该是 deque<T> 数据结构类型,T 是数据类型

这个 stack 类里面其实是用的 deque 作为底层,只是通过进行了封装

deque 的存储是数组形式的,比如存1、2、3,那么数组里面应该是【1,2,3】所以注意区分如果转化为栈的话,那么栈顶应该是3的位置,注意转换! 

入栈
//入栈
void push(const T& date)
{//注意deque是数组形式的存储,栈顶就是数组的尾端x.push_back(date);
}
出栈
//出栈
void pop()
{x.pop_back();
}
获取栈顶元素
//获取栈顶元素
T& top()
{return x.back();
}
判断栈空
//判断栈空
bool empty()
{return x.empty();
}
获取栈元素
//计算栈元素个数
T size()
{return x.size();
}
效果展示
void text1_t()
{stack<int> V;V.push(10);V.push(20);V.push(30);V.push(40);V.push(50);//获取栈顶元素std::cout << V.top() << std::endl;//获取栈元素个数std::cout << V.size() << std::endl;//判断栈空std::cout << V.empty() << std::endl;//出栈顶元素V.pop();//获取栈顶元素std::cout << V.top();
}

queue的底层实现

类模板定义
template<class T,class contain=std::deque<T>>
class queue
{
public://实现private:contain y;
};
入队列
//入队列
void push(const T& date)
{y.push_back(date);
}
获取队头元素
//获取队头元素
T& front()
{return y.front();
}
获取队尾元素
//获取队尾元素
T& back()
{return y.back();
}
出队列
//出队列
void pop()
{y.pop_front();
}
获取队列元素个数
//计算队列元素个数
T size()
{return y.size();
}
判断队空
//判断队空
bool empty()
{return y.empty();
}
效果展示
void text2_t()
{queue<int> V;V.push(10);V.push(20);V.push(30);V.push(40);V.push(50);//获取队头元素std::cout << V.front() << std::endl;//获取队尾元素std::cout << V.back() << std::endl;//获取队元素个数std::cout << V.size() << std::endl;//判断队空std::cout << V.empty() << std::endl;//出队头元素V.pop();//获取队头元素std::cout << V.front();
}

http://www.lryc.cn/news/579881.html

相关文章:

  • 设计模式之代理模式--数据库查询代理和调用日志记录
  • 【C++复习2】内存篇
  • 计算机网络笔记(不全)
  • linux系统安全
  • Rovo Dev CLI Windows 安装与使用指南
  • Word和Excel批量转PDF新方法,操作简单
  • Selenium 安装使用教程
  • Java SE线程的创建
  • 怎么处理[TOO_MANY_REQUESTS/12/disk usage exceeded flood-stage watermark
  • 通道密度与安全性的突破:SiLM5768LCG-DG 六通道互锁隔离器如何重构高可靠系统?
  • Unity HDRP + Azure IoT 的 Python 后端实现与集成方案
  • 使用assembly解决jar包超大,实现依赖包、前端资源外置部署
  • linux 系统已经部署并正常提供服务的docker存储目录迁移
  • 【Prometheus 】通过 Pushgateway 上报指标数据
  • 每天一个前端小知识 Day 21 - 浏览器兼容性与 Polyfill 策略
  • AI+Web3:从Web2到Web3的范式革命与深度技术实践
  • 开源项目XYZ.ESB:数据库到数据库(DB->DB)集成
  • lsblk 显示磁盘(如 /dev/sda)已变大,但分区(如 /dev/sda2)未变,则需要手动调整
  • 微服务架构的演进:迈向云原生
  • 【C++】访问者模式中的双重分派机制详解
  • 【效率提升教程】飞书自动化上传图片和文字
  • jQuery Mobile 安装使用教程
  • 《新消费模式与消费者权益保护研讨会》课题研讨会在北京顺利召开
  • 【嵌入式ARM汇编基础】-ELF文件格式内部结构详解(四)
  • 状态机管家:MeScroll 的交互秩序维护
  • 智能电动汽车 --- 车辆网关路由缓存
  • SAP SD模块之业务功能剖析
  • 京东小程序JS API仓颉改造实践
  • 「AI产业」| 《中国信通院华为:智能体技术和应用研究报告》
  • 【加解密与C】对称加密(四) RC4