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

C++ - 标准库(STL)

目录

一、简介

二、什么时候使用STL

2.1、 vector 和 deque 的使用场景

2.2、 vector 和 deque 的比较

2.3、 list的使用场景


一、简介

C++标准库是C++编程语言的标准程式库,它提供了一个通用的容器类、算法和函数模板库。

其中包括了多种容器类型,例如:

向量(vector)、双向链表(deque)、列表(list)、集合(set)和映射(map)等,

各种容器类型均具备不同的优缺点和使用场景,STL还提供了许多算法和函数模板,使程序员能够轻松地完成一些常见的操作,例如排序、搜索、遍历和数据转换等。

可以通过使用STL,从而提高代码的可读性和可维护性。

为了建立数据结构和算法的一套标准,并且降低他们之间的耦合关系,以提升各自的独立性、弹性、交互操作性(相互合作性,interoperability),诞生了STL。

STL(Standard Template Library,标准模板库),是惠普实验室开发的一系列软件的统称。现在主要出现在 c++中,但是在引入 c++之前该技术已经存在很长时间了。

STL 从广义上分为: 容器(container) 算法(algorithm) 迭代器(iterator)。

容器和算法之间通过迭代器进行无缝连接。STL 几乎所有的代码都采用了模板类或者模板函数,这相比传统的由函数和类组成的库来说提供了更好的代码重用机会。

STL(Standard Template Library)标准模板库,在我们 c++标准程序库中隶属于 STL 的占到了 80%以上。

二、什么时候使用STL

名称vectordequelistsetmultisetmapmultimap
典型内存结构单端数组双端数组双端链表二叉树二叉树二叉树二叉树
是否可以随机存取对key而言:不是
元素查找速度非常慢对key而言:快对key而言:快
元素插入移除尾部头尾两端任何位置----

2.1、 vector 和 deque 的使用场景

vector使用场景:经常查看记录,但却不去删除记录

deque使用场景:排队类似的操作,尾端快速添加,头端移除。如果使用vector,头部移除时会移动很多数据,速度慢。

2.2、 vector 和 deque 的比较

<1> vector.at()比deque.at()效率高,如vector.at(0)是固定的,deque的开始位置 却是不固定的。

<2> 如果有大量释放操作的话,vector花的时间更少,这跟二者的内部实现有关。.

<3> deque支持头部的快速插入与快速移除,这是deque的优点。

2.3、 list的使用场景

支持频繁的不确定位置元素的插入和移除。

2.4、 set的使用场景

要求储存的数据唯一且有序

2.5、 map的使用场景

需要很高的查找效率时使用,通过key查找value。map通过二叉树的查找。

如果是vector容器,最坏的情况下可能要遍历完整个容器才能找到想要的数据。

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

相关文章:

  • Java使用 Scanner连续输入int, String 异常错误输出原因分析
  • pt13网络编程
  • 华为云 绑定/更换证书
  • 重大问题,Windows11出现重大BUG
  • 傅里叶变换解析
  • 你的登录接口真的安全吗?
  • ChatGPT情商很高,但并不适合当搜索引擎
  • Mac 地址与 IP 地址有什么区别?
  • bootloaders
  • PC或服务器装双系统
  • 嵌入式代码查看分析利器---Understand
  • 人群计数经典方法Density Map Estimation,密度图估计
  • 【华为】Smart-Link基础知识
  • 分享24个强大的HTML属性 —— 建议每位前端工程师都应该掌握
  • NIO基础 - 网络编程
  • 06.toRef 和 toRefs
  • RabbitMq、Kafka、RocketMq整理
  • Python多元线性回归预测模型实验完整版
  • C#基础 变量在内存中的存储空间
  • 你最关心的4个零代码问题,ChatGPT 帮你解答了!
  • linux的环境变量
  • openQA----基于openSUSE部署openQA
  • 正则表达式基础一
  • Java中的内存泄露、内存溢出与栈溢出
  • 时序预测 | Matlab实现SSA-GRU、GRU麻雀算法优化门控循环单元时间序列预测(含优化前后对比)
  • Java+springboot开发的医院HIS信息管理系统实现,系统部署于云端,支持多租户SaaS模式
  • 【前端面经】Vue-Vue中的 $nextTick 有什么作用?
  • 基于STATCOM的风力发电机稳定性问题仿真分析(Simulink)
  • 如何写出高质量的代码
  • 15.基于主从博弈的智能小区代理商定价策略及电动汽车充电管理