关于弱符号的解释:
若两个或两个以上全局符号(函数或变量名)名字一样,而其中之一声明为weak symbol(弱符号),则这些全局符号不会引发重定义错误。链接器会忽略弱符号,去使用普通的全局符号来解析所有对这些符号的引用,但当普通的全局符号不可用时,链接器会使用弱符号。当有函数或变量名可能被用户覆盖时,该函数或变量名可以声明为一个弱符号。当weak和alias属性连用时,还可以声明弱别名。
使用例子:
出自:关于gcc属性之weak
弱别名的使用例子:
05 | printf ( "%s\n" ,__FUNCTION__); |
12 | printf ( "%s\n" ,__FUNCTION__); |
18 | asm( ".weak symbol1\n\t .set symbol1, symbol222\n\t" ); |
用下面的命令编译运行会输出symbol1
$ gcc -o weak weak.c symobl222.c
$ ./weak
输出:symbol1
当不链接weak.c,即在symbol1函数为定义时,应用用symbol1的弱别名symbol222代替symbol1。
用下面的命令编译运行会输出symbol222:
$ gcc -o weak symbol222.c
$ ./weak
输出:symbol222
弱符号的例子:
03 | extern void symbol1() __attribute__((weak)); |
06 | printf ( "%s.%s\n" ,__FILE__,__FUNCTION__); |
24 | printf ( "%s.%s\n" ,__FILE__,__FUNCTION__); |
编译运行:
当不编译链接strong.c时:
$ gcc -o weakstrong weak2.c
$ ./weakstrong
输出:weak2.c symbol1
当链接strong.c时,会用strong.c中的强符号symbol1代替weak2.c的的弱符号symbol1:
$ gcc -o weakstrong weak2.c strong.c
$ ./weakstrong
输出:strong.c symbol1
当有两个函数同名时,则使用强符号(也叫全局符号)来代替弱符号。