1.什么是STL
STL(standard template libaray-标准模板库):是C++标准库的重要组成部分,不仅是一个可复用的 组件库,而且是一个包罗数据结构与算法的软件框架。
STL主要包括容器(Containers)、迭代器(Iterators)、算法(Algorithms)和函数对象(Function Objects)四个部分。这些组件可以相互协作,提供高效、灵活的数据处理功能。
2.STL的版本
原始版本
Alexander Stepanov、Meng Lee 在惠普实验室完成的原始版本,本着开源精神,他们声明允许 任何人任意运用、拷贝、修改、传播、商业使用这些代码,无需付费。唯一的条件就是也需要向原 始版本一样做开源使用。 HP 版本--所有STL实现版本的始祖。
P. J. 版本
由P. J. Plauger开发,继承自HP版本,被Windows Visual C++采用,不能公开或修改,缺陷:可读 性比较低,符号命名比较怪异。
RW版本
由Rouge Wage公司开发,继承自HP版本,被C+ + Builder 采用,不能公开或修改,可读性一 般。
SGI版本
由Silicon Graphics Computer Systems,Inc公司开发,继承自HP版 本。被GCC(Linux)采用,可 移植性好,可公开、修改甚至贩卖,从命名风格和编程 风格上看,阅读性非常高。我们后面学习 STL要阅读部分源代码,主要参考的就是这个版本。
3.STL的六大组件
-
容器:STL提供了多种容器来存储数据,包括序列式容器(如vector、deque、list)、关联式容器(如set、map、multiset、multimap)以及哈希容器(如unordered_set、unordered_map)。这些容器提供了不同的数据组织方式,以满足不同的需求。
-
迭代器:迭代器是一种特殊的指针,用于在容器中遍历元素。STL中的迭代器具有类型安全性,并且可以像指针一样进行算术运算和比较操作。通过迭代器,我们可以访问容器中的元素,并对其进行读取、修改等操作。
-
算法:STL提供了大量的算法来对容器中的元素进行操作,如排序、查找、复制等。这些算法都是泛型的,可以适用于不同类型的容器和元素。通过使用算法,我们可以轻松地对容器中的数据进行处理。
-
函数对象:函数对象(也称为仿函数)是一种重载了函数调用运算符的对象。在STL中,函数对象可以作为算法的参数,用于指定对容器元素的操作。函数对象提供了比函数指针更灵活、更强大的功能。
4.STL的优点
- 高效性:STL的容器和算法都是经过优化的,可以提供高效的数据处理性能。
- 泛型编程:STL使用模板技术实现了泛型编程,使得代码可以适用于多种数据类型。
- 可复用性:STL提供的组件都是可复用的,可以方便地集成到不同的应用程序中。
- 灵活性:STL的容器和算法提供了多种选择,可以满足不同的需求。
总的来说,STL是C++编程中非常重要的一部分,它提供了高效、灵活的数据处理功能,并促进了代码的复用和模块化。通过学习和使用STL,我们可以提高编程效率和代码质量。
5.如何学习STL
1.熟练使用STL
2.了解泛型技术的内涵和STL的学理甚至是实作
3.扩充STL
总结的来说就是。能用,明理,能扩展
不懂STL,就不要说你会C++