关于GCC属性中的弱符号(weak symbol)

来源:互联网 发布:win8办公软件下载 编辑:程序博客网 时间:2024/05/08 00:40
关于弱符号的解释:
若两个或两个以上全局符号(函数或变量名)名字一样,而其中之一声明为weak symbol(弱符号),则这些全局符号不会引发重定义错误。链接器会忽略弱符号,去使用普通的全局符号来解析所有对这些符号的引用,但当普通的全局符号不可用时,链接器会使用弱符号。当有函数或变量名可能被用户覆盖时,该函数或变量名可以声明为一个弱符号。当weak和alias属性连用时,还可以声明弱别名。

使用例子:

出自:关于gcc属性之weak

弱别名的使用例子:

01//weak.c
02#include <stdio.h>
03void symbol1()
04{
05    printf("%s\n",__FUNCTION__);
06}
07 
08//symbol222.c
09 
10void symbol222()
11{
12    printf("%s\n",__FUNCTION__);
13}
14 
15//void symbol1() __attribute__ ((weak,alias("symbol222")));  //这一包与下面的asm()一句是等效的。
16int main()
17{
18    asm(".weak symbol1\n\t .set symbol1, symbol222\n\t");
19    symbol1();
20    return 0;
21}

用下面的命令编译运行会输出symbol1

$ gcc -o weak weak.c symobl222.c

$ ./weak

输出:symbol1

当不链接weak.c,即在symbol1函数为定义时,应用用symbol1的弱别名symbol222代替symbol1。

用下面的命令编译运行会输出symbol222:

$ gcc -o weak symbol222.c

$ ./weak

输出:symbol222

弱符号的例子:

01//weak2.c
02#include <stdio.h>
03extern void symbol1() __attribute__((weak));
04void symbol1()
05{
06    printf("%s.%s\n",__FILE__,__FUNCTION__);
07}
08 
09 
10int main()
11{
12    //asm(".weak symbol1\n\t .set symbol1, symbol222\n\t");
13    symbol1();
14    return 0;
15}
16 
17 
18//strong.c
19 
20#include <stdio.h>
21 
22void symbol1()
23{
24    printf("%s.%s\n",__FILE__,__FUNCTION__);
25}

编译运行:

当不编译链接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

 当有两个函数同名时,则使用强符号(也叫全局符号)来代替弱符号。

0 0