C++的STL开端

发布于:2022-07-24 ⋅ 阅读:(265) ⋅ 点赞:(0)

目录

STL基本概念

STL 中容器、算法、迭代器


STL基本概念

  • STL 是什么?
  1. STL(Standard  Template  Library标准模板库

--------------------------

  • STL 广义分为
  1. 容器(container)
  2. 算法(algorithm)
  3. 迭代器(iterator)

--------------------------

  • STL 的作用:
  1. 提升代码复用性
  2. 建立数据结构和算法的一套标准

--------------------------

  • STL 的实现?
  1. 几乎所有的代码都是采用类模板函数模板实现
  2. 容器和算法之间通过迭代器进行连接

--------------------------

  • STL 六大组件
  1. 容器:各种数据结构,如 vector、list、deque、set、map等,存放数据
  2. 算法:常用算法,如 sort、find、copy、for_each等
  3. 迭代器:扮演容器与算法之间的胶合剂
  4. 仿函数:行为类似函数,可作为算法的某种策略
  5. 适配器(配接器):修饰容器或者仿函数或者迭代器的东西
  6. 空间配置器:负责空间的配置与管理

STL 中容器、算法、迭代器

  • 容器(container)

简单说就是放数据的地方

STL 容器就是运用最广泛的一些数据结构实现出来的

常用的数据结构:数组、链表、树、栈、队列、集合、映射表 等

这些容器分为序列式容器关联式容器两种:

  1. 序列式容器:强调值的排序,序列式容器中的每个元素均有固定的位置
  2. 关联式容器:二叉树结构,各元素之间没有严格的物理上的顺序关系

-------------------

  • 算法(algorithm)

简单说就是解决问题的方法

有限的步骤,解决逻辑或数学上的问题,这门学科叫算法

算法分为质变算法非质变算法两种:

  1. 质变算法:会改变区间内元素的内容,如:拷贝、替换、删除等
  2. 非质变算法:不会改变区间内的元素内容,如:查找、计数、遍历、寻找等

-------------------

  • 迭代器(iterator):

容器和算法之间的连接

提供一种方法,使之能依序寻访某个容器所含的各个元素,而又无需暴露该容器的内部表示方式。

每个容器都有自己专属的迭代器

迭代器使用类似指针

迭代器种类

种类 功能 支持运算
输入迭代器 对数据的只读访问 ++、==、!=
输出迭代器 对数据的只写访问 ++
前向迭代器 读写操作,并向前推进迭代器 ++、==、!=
双向迭代器 读写操作,并向前和向后操作 ++、--
随机访问迭代器 读写操作,可以跳跃的方式访问任意数据,功能最强大迭代器 ++、--、[n]、-n、<、<=、>、>=

常用的容器迭代器为后两种


本文含有隐藏内容,请 开通VIP 后查看

网站公告

今日签到

点亮在社区的每一天
去签到