【C++】STL 标准模板库

本文介绍了C++中的标准模板库(STL),包括其定义、不同版本的历史、以及STL的六大组件,如vector、list和容器适配器等。学习者可以通过阅读这些内容来提高代码复用性和效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


一、STL的介绍

1. 什么是STL

STL(standard template libaray-标准模板库):是C++标准库的重要组成部分,不仅是一个可复用的组件库,而且是一个包罗数据结构与算法的软件框架

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

在这里插入图片描述

4、学习博客

二、STL的总结

STL 提供了六大组件,彼此组合套用协同工作。这六大组件分别是:

  • 容器(Containers):各种数据结构,如 vector、list、deque、set、map、unordered_map 等。从实现的角度来看,容器是一种类模板。
  • 算法(Algorithms):各种常用算法,提供了执行各种操作的方式,包括对容器内容进行排序、搜索、逆置、排列、拷贝、删除等操作,比如sort、inary_search、reverse、next_permutation、copy、remove。从实现的角度来看,STL 算法是一种 函数模板。
  • 迭代器(Iterators):迭代器用于遍历容器中的元素,是所谓的“泛型指针”。从实现角度来看,迭代器是一种将 operator*、operator->、operator++、operator-- 等指针操作予以重载的类模板。
  • 仿函数(Functors):也称为函数对象(Function object),行为类似函数,可作为算法的某种策略(如在sort中传入一共greater<int>类型的一个仿函数实现降序排序)。从实现角度来看,仿函数是一种重载了 operator() 的 类 或者 类模板。
  • 适配器(Adaptors):一种用来修饰容器或者仿函数或迭代器接口的东西。例如 STL 提供的 queuestack,就是一种空间配接器,因为它们的底部完全借助于 deque
  • 分配器(Allocators):也称为空间配置器,负责空间的配置与管理。从实现的角度来看,配置器是一个实现了动态配置空间、空间管理、空间释放的类模板。

STL 中组件的关系

  • 迭代器是容器与算法之间的胶合剂,只有通过迭代器算法才能对容器进行操作。
  • 适配器是标准库中的一个通用概念,容器、迭代器和函数都有适配器。本质上,一个适配器是一种机制,能使某种事物的行为看起来像另外一种事物一样。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

七凌、

感谢,我会加油创作出更好的作品

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值