(1)通过把调用链上的函数定义,全部注释过来,学习了vector 的设计思路。vector原头文件总共3000 行。去掉了vector的bool特化类型 ,源代码文件因为带有大量的注释,也达到了8000 行。但可读性大大增加。谢谢这个世界上可爱的人们。
(2)如下图,vector的一种初始化方式:

为什么可行呢,因为实参被编译器初始化给了另一个 initializer_list 类型的变量,再以 initializer_list 类型的变量为实参,来初始化vector。 虽然我们没有直接使用过 initializer_list 类型,但已经间接因为这个类型受益了,这个类型的变量,接收了我们用{ }传递进来的一串数据。


对于以上的代码执行逻辑,可以反汇编验证一下:

(3) 以下是 vector 结构的组成概述





( 4) 这里以 vector 为例,分析容器析构时的内存管理:

(5) 以 vector 容器为例,来探讨容器在进程退出时的内存泄露问题。该结论应该适用于 STL 库中的所有容器:

以上只是理论分析,用内存检测工具测试一下咱们的结论:

++ 也可以用 linux 里的 valgrind 来耍一耍:

(6)
谢谢
本文详细介绍了通过分析vector的源代码学习到的设计思想,包括对3000行源码的注释处理,使得代码可读性增强。作者提到了一种使用initializer_list的vector初始化方式,并解释了其工作原理,指出这种机制在处理花括号初始化时的作用。此外,还简要概述了vector的数据结构组成。
4435

被折叠的 条评论
为什么被折叠?



