STL标准模板库

STL是标准模板库,是标准库的重要组成部分,将常见的数据结构以模板的方式进行封装,并提供一些灵活的算法

是程序员避免做大量重复性的工作而诞生出的一套标准

从广义上分为容器、算法、迭代器

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

STL提供六大组件 分别是容器、算法、迭代器、仿函数、适配器、空间配置器

容器 :各种数据结构,如vector、list、deque、set、map、用来存放数据,从实现角度,STL容器是一种class template

算法: 各种常用算法,如sort、find、copy、for_each,从实现角度看,STL算法是一种functior tempalte

迭代器: 扮演了容器和算法之间的胶合剂、共有五种类型,从实现角度,迭代器是一种将operator*,operator->,operator++,operator-等指针相关操作予以重载的class template,所有STL容器都有自己的专属迭代器,原生指针也是一种迭代器

仿函数: 行为类似函数,可作为算法的某种策略,从实现角度看,仿函数是一种重载了operator()的class或则class template

适配器 :一种用来修饰容器或则仿函数或迭代器接口的东西

空间配置器: 负责空间的配置与管理,从实现角度看,配置器一个实现动态空间配置、空间管理、空间释放的class tempalte

STL优点:高重用性,高性能,高移植性、跨平台

高可重用性:STL 中几乎所有的代码都采用了模板类和模版函数的方式实现,这相比于传统的由函数和类组成的库来说提供了更好的代码重用机会。

高性能:如 map 可以高效地从十万条记录里面查找出指定的记录,因为 map 是采用红黑树的变体实现的。

高移植性:如在项目 A 上用 STL 编写的模块,可以直接移植到项目 B 上。

相关推荐
凡人叶枫38 分钟前
Effective C++ 条款41:了解隐式接口和编译期多态
java·开发语言·c++·effective c++
凡人叶枫43 分钟前
Effective C++ 条款42:了解 typename 的双重意义
java·linux·服务器·c++
小胖xiaopangss1 小时前
BRpc使用
c++·rpc
-森屿安年-1 小时前
63. 不同路径 II
c++·算法·动态规划
chase_my_dream1 小时前
Cartographer详细讲解
c++·人工智能·自动驾驶
森G1 小时前
75、服务器源码解析---------云视频服务项目
linux·服务器·网络·c++·qt
碧海蓝天20222 小时前
C++法则24:在标准 C++ 中,没有任何可移植的方式判断指针 T* pt 指向的内存位置是否已经 构造了对象,程序员必须手动跟踪哪些元素已构造。
java·开发语言·c++
charlie1145141912 小时前
现代C++指南:Lambda,让我们用另一种方式持有函数
开发语言·c++
森G2 小时前
77、线程池原理和实现------服务器源码解析----云视频服务项目
服务器·c++·qt
.千余3 小时前
【C++】模板进阶全解:非类型参数|全特化|偏特化|分离编译完全指南
开发语言·c++·笔记·学习·其他