C++ Standard Library
architecure & sources
C标准库 -> 一个一个单一的函数function -> 彼此几乎无关联
c++标准库 -> 六个部分 -> 彼此之间有紧密的关联
c++标准库主要是用模板做出来的
泛型编程(Generic Programming)
使用模板作为主要工具来编写程序 -> templates模板的意义和运用
与面向对象编程(oop -> Object Oriented Programming)的根本差异
-
level 0: 使用c++STL -
level 1: 认识c++STL-> 使用部件的时候-
清楚他们在内存当中的布局.以及如何扩展的
-
当元素增加的时候如何变化的
-
进而判断用什么部件、容器、算法
-
-
level 2: 良好使用c++STL-> 对c++STL有一个清楚的认识和了解之后才能够做到良好的使用 -
level 3: 扩充c++STL-> 极少数
c++ Standard Library && c++ Standard Template Library
c++ Standard Library
-
以
headr files的形式出现 -> 不是编译好的,可以看到source code-
c++标准库头文件不带.h名 ->#include <vector>
-
c++STL是指六大部件.加上其他的东西才是c++标准库
在头文件内在进行一层封装就是namespace -> 头文件内又打了一个包
c++STL
STL六大部件(components)
-
容器(
Containers) -> 解决掉内存分配的问题 ->template class-> 数据在容器里面 -> 每一种容器对应一个头文件 -
分配器(
Allocators) -> 支持容器解决内存的问题 -
算法(
Algorithms) -> 容器下的模板函数 -> 不在容器的class里面 -> 模板编程 -
迭代器(
Iterators) -> 数据和算法(操作方式)中间的桥梁称之为迭代器 -> 泛化的指针 -
适配器(
Adapters) -> 转换容器、迭代器或者转换仿函数 -
仿函数(
Functors) -> 两个类或者class进行计算就可以写一些仿函数

数据结构+算法=程序
面向对象(oop) -> 数据和处理数据的函数都放在class里面
上述STL使用示例代码:
容器特点
-
容器不一定是连续空间
-
begin()指向第一个元素.end()指向最后一个元素的下一个元素 -> 前闭后开区间 -> 所以end()不可以解引用拿地址.因为拿不到想要的地址 -
上面两个方法返回的是泛化指针
示例代码:

浙公网安备 33010602011771号