弱符号和extern “c”,这两者在某种程度上没有什么关联,一个是编译器提供的属性选项(弱符号),一个是C++语言中用来兼容C程序的机制(extern “c”,当然它与编译器也密切相关,下文细述)。这所以把这两种放在一起说,是因为最近在研究TCMalloc源码时遇到的一些问题,让我感到和困惑。这个问题描述如下:
1. 实例场景
在TCMalloc的malloc_hook.cc中,有这么一个函数声明:
# define ATTRIBUTE_WEAK __attribute__((weak))
extern "C" {
ATTRIBUTE_WEAK voidMallocHook_InitAtFirstAllocation_HeapLeakChecker();
}
声明之后,后面的代码使用这个函数,之后还有这个函数的定义:
// Weak default initialization functionthat must go after its use.
extern "C" voidMallocHook_InitAtFirstAllocation_HeapLeakChecker() {
//Do nothing.
}
在另一个文件heap-checker.cc中,还有同一个函数的定义:
extern "C" voidMallocHook_InitAtFirstAllocation_HeapLeakChecker() {
HeapLeakChecker_BeforeConstructors();