TCMalloc的使用与源码剖析之五---------TCMalloc中涉及到的几个重要的数据结构

来源:互联网 发布:centos编译安装php7.1 编辑:程序博客网 时间:2024/05/19 00:47

        在initStaticVars()里面首先会调用SizeMap.initSizeMap是一个非常关键的数据结构,SizeMap里面涉及到几个关键的数据结构class_array_class_to_size_class_to_pages_num_objects_to_move_

        其中class_array将一个size映射成为一个class num,被映射的class num一共有kNumClassesnum,而class_to_size_class_to_pages_num_objects_to_move_这三个数组都是拥有kNumClassesnum的数组。 所以根据class_array映射得到的class num,也即另外3个数组的索引号,就可以使用另外3个数组。

根据这个索引号可以从class_to_size数组中得到基于这个索引(也即最开始的size)的可分配obj的最大size,假设这个大小的size叫做Asize

可以从num_objects_to_move数组中得到基于这个索引(也即最开始的size)的在ThreadCacheCentralCache之间移动的obj的数量,该obj的大小就是Asize

可以从class_to_pages_数组中得到基于这个索引(也即最开始的size)的在CentralCache和中央页堆之间移动的页面数量。

         class_to_size数组,num_objects_to_move数组,class_to_pages_数组均是在SizeMap::Init()函数中被初始化。  class_to_size_数组最终会被初始化为8,16,32,48(16递增,直到128字节)128字节后,是另外一直形式的递增,一直到kMaxSize到了kMaxSize后,又换一种形式的递增

0 0