C++ STL(第一篇:概述)

STL是Stander Temple Library(标准模板库)的简称。它是一套功能强大的C++模板类,提供了通用的模板类和函数,这些模板类和函数可以实现多种流行的常用的算法和数据结构。

STL提供了六大组件,彼此可以组合套用:

  • 容器:各种数据结构,如vector、list、deque、set、map。用来存放数据。
  • 算法:各种常见算法,如sort、search、copy、erase…
  • 迭代器:扮演容器与算法之间的胶合剂,是所谓的“泛型指针”。其中包含了5种迭代器(只读、只写、单向、双向和随机),以及从它衍生变化。从实现的角度来看,迭代器是一种将*、->、++、–等指针相关操作予以重载的类模板。所有STL容器都附带有自己专属的迭代器
  • 仿函数:行为类型函数,可作为算法的某种策略。从实现的角度来看,仿函数是一种重载了()的类或类模板。
  • 配接器:一种用来修饰容器或仿函数或迭代地的接口。例如,STL提供的queue和stack,虽然看似容器,其实只能算是一种容器配接器,因为他们的底层完全借助deque。
  • 配置器:负责空间配置与管理。从实现角度来看,配置器是一个实现了动态空间配置、空间管理、空间释放的类模板。

STL有很多个版本,版本不同实现有稍许不一样。

感谢大家,我是假装很努力的YoungYangD(小羊)

参考资料:
《STL源码剖析》

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值