一 tcmalloc简介
1.tcmalloc(thread-caching malloc),即线程缓存malloc,为每个线程分配本地的cache;
2.线程所需的小对象(几十个字节到1K左右)都从本地cache取;
3.同时tcmalloc维护进程级别的cache,大对象从这里的cache取数据,但同时tcmalloc会加自旋锁(spinlock),这样大对象分配内存会耗费更多的性能;
4.如果应用程序需要频繁分配与释放小对象,则可以考虑使用tcmalloc。
二 tcmalloc使用
应用程序无需修改new或者malloc,只需要在安装tcmalloc系统上加上-ltcmalloc这样编译选项即可,如:
g++ -std=c++11 -g -o Test test.cpp -I ./ -ltcmalloc
三 tcmalloc安装
tcmalloc已在centos7.5编译成动态库,获取路径:\\10.50.21.118\Common\tcmalloc
#先安装unwind
./configure && make && make install
#后安装tcmalloc
./configure --enable-frame-pointers && make && make install
四 tcmalloc测试
1.测试环境:centos7.5 单核虚拟机
2.测试方法:单进程,单线程模式,使用new和delete对不同类型数据(100字节到1600字节)申请和释放,对每类数据测试6次,算平均耗时。
3.测试结果:
4.测试源码:https://github.com/wangzhicheng2013/tcmalloc
5.测试结论:
(1)小对象(1K以下),tcmalloc有明显优势;
(2)通过分析现场包,每个分组packet基本在几十字节到1K左右,因此可以运用tcmalloc进行优化。
标签:测试,make,cache,线程,&&,字节,性能,tcmalloc From: https://blog.51cto.com/u_15899033/5902976