C++ STL

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的六大组件

  1. 容器:STL提供了多种容器来存储数据,包括序列式容器(如vector、deque、list)、关联式容器(如set、map、multiset、multimap)以及哈希容器(如unordered_set、unordered_map)。这些容器提供了不同的数据组织方式,以满足不同的需求。

  2. 迭代器:迭代器是一种特殊的指针,用于在容器中遍历元素。STL中的迭代器具有类型安全性,并且可以像指针一样进行算术运算和比较操作。通过迭代器,我们可以访问容器中的元素,并对其进行读取、修改等操作。

  3. 算法:STL提供了大量的算法来对容器中的元素进行操作,如排序、查找、复制等。这些算法都是泛型的,可以适用于不同类型的容器和元素。通过使用算法,我们可以轻松地对容器中的数据进行处理。

  4. 函数对象:函数对象(也称为仿函数)是一种重载了函数调用运算符的对象。在STL中,函数对象可以作为算法的参数,用于指定对容器元素的操作。函数对象提供了比函数指针更灵活、更强大的功能。

4.STL的优点

  • 高效性:STL的容器和算法都是经过优化的,可以提供高效的数据处理性能。
  • 泛型编程:STL使用模板技术实现了泛型编程,使得代码可以适用于多种数据类型。
  • 可复用性:STL提供的组件都是可复用的,可以方便地集成到不同的应用程序中。
  • 灵活性:STL的容器和算法提供了多种选择,可以满足不同的需求。

总的来说,STL是C++编程中非常重要的一部分,它提供了高效、灵活的数据处理功能,并促进了代码的复用和模块化。通过学习和使用STL,我们可以提高编程效率和代码质量。

5.如何学习STL

1.熟练使用STL

2.了解泛型技术的内涵和STL的学理甚至是实作

3.扩充STL

总结的来说就是。能用,明理,能扩展

不懂STL,就不要说你会C++

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值