最近在阅读tcmalloc代码时发现使用了很多__attribute__((weak)),上网搜了以下有所了解。
弱符号:
若两个或两个以上全局符号(函数或变量名)名字一样,而其中之一声明为weak symbol(弱符号),则这些全局符号不会引发重定义错误。链接器会忽略弱符号,去使用普通的全局符号来解析所有对这些符号的引用,但当普通的全局符号不可用时,链接器会使用弱符号。当有函数或变量名可能被用户覆盖时,该函数或变量名可以声明为一个弱符号。弱符号也称为weak alias(弱别名)。
总结:
- 给函数加上weak属性时,即使函数没定义,函数被调用也可以编译成功。
- 当有两个函数同名时,则使用强符号(也叫全局符号,即没有加weak的函数)来代替弱符号(加weak的函数)
以下转自:https://blog.csdn.net/zzftimfan/article/details/41843235
参考:https://blog.csdn.net/l09711/article/details/18096231
https://blog.csdn.net/xyh01215_intosky/article/details/17685793
#if defined ( GNUC )
#ifndef __weak
#define __weak attribute((weak))
#endif /* __weak /
#ifndef __packed
#define __packed attribute((packed))
#endif / __packed /
#endif / GNUC */
用于函数声明,__weak声明于函数时,在工程中可以没有函数实体,当函数中有实体函数时(没有带__weak)在函数调用的时候只调用没有带__weak的函数,如下:
int func(void)
{
Func_t();
}
__weak void Func_t(void)
{
}
其实这样做的原因是为了使软件框架更加利于扩展和兼容;同时也满足没有实体函数而报编译错误,如果在上述的结构中要求在Func_t函数中实现加法运算,函数只要做如下修改:
void Func_t(void)
{
c=a+b;// 假设a,b,c都是全局变量;
}
PS:注意函数头没有带__weak。