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

 當有兩個函數同名時,則使用強符號(也叫全局符號)來代替弱符號。

相關文章
相關標籤/搜索