最近在用vs2010编译内存管理库tcmalloc时,碰到了两个问题,记录一下
1.由于在vs2010中log2()还不是标准库函数,因此,在编译的过程中会提示log2()未定义。于是就在使用该函数的sample.h中自己添加了一个log2()的实现,log2(x)=log(x)/log(2),但是由于是要从dll中导出使用,所以该函数的声明需要加上PERFTOOLS_DLL_DECL。
2.在编译完,使用tcmalloc的过程中,在debug模式下,程序会在tcmalloc初始化阶段卡住,无法继续运行,测试程序无法进入main函数。后来一步步调试,发现在stacktrace.cc->init_default_stack_impl_inner() ->getenv()会导致程序卡住,由于在官方gibhub的issues中有提到过另外一个地方有getenv()引起的死锁,于是按照那个方法,将getenv()改成TCMallocGetenvSafe()后,问题解决,但是这个问题在其他同事的电脑上不出现,并且,在我自己的电脑上也不是一直出现,有时候也不会出现,具体原因现在未知,可能跟初始化完成的时机相关,在debug模式下,程序运行速度较慢,可能更容易出现资源争用的情况。