目录
STL基本概念
- STL 是什么?
- STL(Standard Template Library,标准模板库)
--------------------------
- STL 广义分为:
- 容器(container)
- 算法(algorithm)
- 迭代器(iterator)
--------------------------
- STL 的作用:
- 提升代码复用性
- 建立数据结构和算法的一套标准
--------------------------
- STL 的实现?
- 几乎所有的代码都是采用类模板和函数模板实现
- 容器和算法之间通过迭代器进行连接
--------------------------
- STL 六大组件
- 容器:各种数据结构,如 vector、list、deque、set、map等,存放数据
- 算法:常用算法,如 sort、find、copy、for_each等
- 迭代器:扮演容器与算法之间的胶合剂
- 仿函数:行为类似函数,可作为算法的某种策略
- 适配器(配接器):修饰容器或者仿函数或者迭代器的东西
- 空间配置器:负责空间的配置与管理
STL 中容器、算法、迭代器
- 容器(container):
简单说就是放数据的地方
STL 容器就是运用最广泛的一些数据结构实现出来的
常用的数据结构:数组、链表、树、栈、队列、集合、映射表 等
这些容器分为序列式容器和关联式容器两种:
- 序列式容器:强调值的排序,序列式容器中的每个元素均有固定的位置
- 关联式容器:二叉树结构,各元素之间没有严格的物理上的顺序关系
-------------------
- 算法(algorithm):
简单说就是解决问题的方法
有限的步骤,解决逻辑或数学上的问题,这门学科叫算法
算法分为质变算法和非质变算法两种:
- 质变算法:会改变区间内元素的内容,如:拷贝、替换、删除等
- 非质变算法:不会改变区间内的元素内容,如:查找、计数、遍历、寻找等
-------------------
迭代器(iterator):
容器和算法之间的连接
提供一种方法,使之能依序寻访某个容器所含的各个元素,而又无需暴露该容器的内部表示方式。
每个容器都有自己专属的迭代器
迭代器使用类似指针
迭代器种类
种类 功能 支持运算 输入迭代器 对数据的只读访问 ++、==、!= 输出迭代器 对数据的只写访问 ++ 前向迭代器 读写操作,并向前推进迭代器 ++、==、!= 双向迭代器 读写操作,并向前和向后操作 ++、-- 随机访问迭代器 读写操作,可以跳跃的方式访问任意数据,功能最强大迭代器 ++、--、[n]、-n、<、<=、>、>= 常用的容器迭代器为后两种
本文含有隐藏内容,请 开通VIP 后查看