在项目中,使用到了tcmalloc作为自己的内存分配库,但是使用了一段时间后,发现central freelist中的内存一直没有释放给系统。
最后检查了一下,发现原因是:
tcmalloc事先后分配一大块内存,减少分配内存的系统调用,每次会根据需要分配一个或多个page;
central freelist是用span管理的,一个span是多个page,
thread cache 中使用的小内存会从span中割一块,导致span的引用计数加1。
出现 central
freelist中用很多内存,但是就是释放不了,原因就是span的引用计数没有归零,倒是tcmalloc没有将整个span释放给系统。
解决方法:
1. 不使用cache,将用- DSMALL_BUT_SLOW 将 tcmalloc从新编译一遍;
2. 检查自己的代码,看看那些地方的连续内存,只释放了一部分。
参见:
http://blog.csdn.net/lantianjialiang/article/details/50510890
https://groups.google.com/forum/#!topic/google-perftools/glLYD1o2_-U