第十六节 深度探索vector
vector源码剖析
vector内存2倍扩充,是在另外的地方重新申请内存,将数据搬过去-
前闭后开区间

- 2倍扩充方法,reallocation
insert_aux函数中再次判断,原因是可能有其他放元素的操作如insert

- 也要拷贝插入之后的数据,考虑到
insert插入某个位置,红色框部分
vector's iterator
vector结点是连续的,iterator不需要是类,是个指针即可。- 算法问的五种相关类型,通过
iterator traits实现 - 通过指针偏特化

G4.9 vetor and iterator

- 变得复杂,但是追踪其根源和G2.9本质一样。

第十七节 深度探索array和forward list
容器array
TR1技术报告1 ,C++1.0-1998和c++2.0-2011之间的过渡版本- 源码很清晰,没有构造和析构函数;申明数组大小;用指针当迭代器

G4.9变得复杂
容器forward-list



