初识STL

由来

大多是情况下,由于数据结构和算法未能有一套标准,导致被迫从事大量重复工作,软件界想要建立一套可重复利用的东西,于是诞生STL(Standard Template Library,标准模板库)。STL 几乎所有的代码都采用了模板类或者模板函数。也就是说,别人把方法都封装好了,只需要调用便可。

六大件

STL从广义上分:
容器(container) 算法(algorithm) 迭代器(iterator)。 容器算法之间通过迭代器进行无缝连接。

STL从狭义上看:
又有六大组件,分别是:容器、算法、迭代器、仿函数、适配器(配接器)、空间配置器

  1. 容器:用来存放数据。
  2. 算法:各种常用的算法。
  3. 迭代器:扮演了容器与算法之间的胶合剂。
  4. 仿函数:行为类似函数。
  5. 适配器:一种用来修饰容器或者仿函数或迭代器接口的东西。
  6. 空间配置器:负责空间的配置与管理。

容器:正如字面意思。就是将运用 最广泛的一些数据结构(数组, 链表, 栈, 队列, 树,集合等)实现出来。这些容器分为序列式容器(强调值的排序,各元素均有固定的位置)和关联式容器(二叉树结构,各元素没有严格的顺序)两种。

算法:破题之法
算法分为:质变算法(运算过程中会更改区间内的元素) 和 非质变算法(运算过程中不会更改区间内的元素)。

迭代器:容器和算法之间粘合剂
迭代器使用类似于指针,每个容器都有自己专属的迭代器。
提供一种方法,使之能够依序寻访某个容器所含的各个元素,而又无需暴露该容器的内部表示方式。

种类功能支持运算
输入迭代器对数据的只读访问只读,支持++、==、!=
输出迭代器对数据的只写访问只写,支持++
前向迭代器读写操作,并能向前推进迭代器读写,支持++、==、!=
双向迭代器(常用)读写操作,并能向前和向后操作读写,支持++、–,
随机访问迭代器 (常用)读写操作,可以以跳跃的方式访问任意数据,功能最强的迭代器读写,支持++、–、[n]、-n、<、<=、>、>=
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值