GCC学习笔记(三)——关于GCC属性中的弱符号(weak symbol)

关于弱符号的解释:
若两个或两个以上全局符号(函数或变量名)名字同样,而其中之一声明为weak symbol(弱符号),则这些全局符号不会引起重定义错误。连接器会忽略弱符号,去使用普通的全局符号来解析全部对这些符号的引用,但当普通的全局符号不可用时,连接器会使用弱符号。当有函数或变量名可能被用户覆盖时,该函数或变量名能够声明为一个弱符号。当weak和alias属性连用时,还能够声明弱别名。

使用例子:

出自:关于gcc属性之weak函数

弱别名的使用例子:.net

//weak.c
#include <stdio.h>
void symbol1()
{
    printf("%s\n",__FUNCTION__);
}

//symbol222.c

void symbol222()
{
    printf("%s\n",__FUNCTION__);
}

//void symbol1() __attribute__ ((weak,alias("symbol222")));  //这一包与下面的asm()一句是等效的。
int main()
{
    asm(".weak symbol1\n\t .set symbol1, symbol222\n\t");
    symbol1();
    return 0;
}

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

$ gcc -o weak weak.c symobl222.ccode

$ ./weakblog

输出:symbol1get

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

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

$ gcc -o weak symbol222.c编译

$ ./weakclass

输出:symbol222变量

弱符号的例子:

//weak2.c
#include <stdio.h>
extern void symbol1() __attribute__((weak));
void symbol1()
{
    printf("%s.%s\n",__FILE__,__FUNCTION__);
}


int main()
{
    //asm(".weak symbol1\n\t .set symbol1, symbol222\n\t");
    symbol1();
    return 0;
}


//strong.c

#include <stdio.h>

void symbol1()
{
    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

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

相关文章
相关标签/搜索