TCMalloc的使用与源码剖析之九---------一些未解决的问题
2016-10-22 11:17
295 查看
1. 线程缓冲区的大小的确定
Tcmallloc官方文档上说线程缓冲区的大小是慢启动的,在源码中找到了它的慢启动代码,但是还没有研究明白这个慢启动到底是一个什么逻辑。程序里有三处地方与该缓冲区大小确定有关,三处地方分别是FetchFromCentralCache,ListTooLong以及Scavenge。具体怎么确定的还没有研究,先做个备忘录而已。
恰当线程缓冲区大小至关重要,如果缓冲区太小,我们需要经常去CentralHeap分配;如果线程缓冲区太大,又致使大量对象闲置而浪费内存。
注意到恰当的线程缓冲区的大小对内存的释放一样重要。如果没有线程缓冲,每次内存释放都需要把内存移回到Central Heap。同样,一些线程有不对称的内存分配和释放行为(例如:生产者和消费者线程),所以确定恰当的缓冲区大小也很棘手。
确定缓冲区大小,我们采用“慢开始”算法来确定每一个尺寸内存链表的最大长度。当某个链表使用更频繁,我们就扩大他的长度。如果我们某个链表上释放的操作比分配操作更多,它的最大长度将被增长到整个链表可以一次性有效的移动到Central
Heap的长度。
下面的伪代码说明了这种慢开始算法。注意到num_objects_to_move对每一个尺寸是不同的。通过移动特定长度的对象链表,中央缓冲可以高效的将链表在线程中传递。如果线程缓冲区的需要小于num_objects_to_move,在中央缓冲区上的这种操作具有线性的时间复杂度。使用num_objects_to_move作为从中央缓冲区传递的对象数量的缺点是,它将不需要的那部分对象浪费在线程缓冲区。
相关文章推荐
- sourceforge使用svn管理源码以及使用eclipse的一些问题
- TCMalloc的使用与源码剖析之四---------内存在各层之间的传递
- 目前使用Z-Stack未解决的一些问题
- TCMalloc的使用与源码剖析之二---------TCMalloc内存分配与管理简述
- ListIterator中方法的源码实现,及一些异常问题剖析
- TCMalloc的使用与源码剖析之六---------TCMalloc中内存分配流程
- C++ Standard Stl -- SGI STL源码学习笔记(07) stl_vector 与 一些问题的细化 3 resize函数剖析
- TCMalloc的使用与源码剖析之三---------TCMalloc的内存分配的主要层次
- TCMalloc的使用与源码剖析之八---------TCMalloc内存分配与释放的管理之内存泄露检查
- TCMalloc的使用与源码剖析之十--------TCMalloc与APR,ptmalloc的分析比较
- TCMalloc的使用与源码剖析之七---------TCMalloc中内存释放流程
- TCMalloc的使用与源码剖析之五---------TCMalloc中涉及到的几个重要的数据结构
- TCMalloc的使用与源码剖析之一---------TCMalloc 安装和使用
- 使用tcmalloc的一些问题
- C++ Standard Stl -- SGI STL源码学习笔记(06) stl_vector 与 一些问题的细化 2 push_back函数剖析
- Linux 使用中的一些问题杂集
- 使用 Castle ActiveRecord 开发发现的一些问题
- Appfuse 使用中的一些问题
- tomcat,jboss使用中遇到的一些问题的解决
- VS2005下组件ReportView使用时的一些问题