c/c++的全局变量
https://www.byvoid.com/blog/c-global-variables-in-multiple-files
首先看一段代碼
func.c
int buf = 0;void func() {buf = 2;/* Do something else */ }main.c
#include <stdio.h>int buf; void func();int main() {buf = 1;func();printf("%d\n", buf);return 0; }編譯兩個文件,輸出的結果是怎樣的呢?一眼看上去,可能會輸出1,因為兩個全局變量buf在不同文件中,又沒有extern聲明,顯然是兩個嘛。然而實際上它的運行結果卻是2,這說明了這兩個文件中引用到的其實是一個變量!
這是為什么呢?原因是在編譯時,C語言編譯器將全局符號標記為strong和weak兩類:
- 函數和初始化的全局符號被標記為strong
- 未初始化的全局符號被標記為weak
連接時,連接器對多重定義的全局符號的解析原則如下:
- 同一個符號不允許有多個strong定義;
- 假如一個符號有一個strong定義和多個weak定義,那么采用該符號的strong定義;
- 假如一個符號有多個weak定義,那么選取任意一個weak定義
由于兩個變量一個初始化了,一個沒有初始化,所以一個是strong,一個是weak,所以連接器在符號解析時會把他們當成一個。
如果我們把main.c中的buf也初始化了:
#include <stdio.h>int buf = 0; void func();int main() {buf = 1;func();printf("%d\n", buf);return 0; }再次編譯就會發現
duplicate symbol _buf in:/var/folders/44/_cc501qx1jd1p5bfrjbk6b100000gn/T//ccZ87C6g.o/var/folders/44/_cc501qx1jd1p5bfrjbk6b100000gn/T//ccZlES8n.o ld: 1 duplicate symbol for architecture x86_64 collect2: ld returned 1 exit status這是因為兩個全局變量都是strong的。
Makefile:tst:main.o func.o
gcc -o tst main.o func.o
main.o:main.c
func.o:func.c
clean:
rm *.o tst
注意文件里面的對齊是一個tap而不是四個空格
先對兩個.c文件編譯生成.o文件,再將.o文件鏈接成可執行文件
如果直接用g++ -o tst main.c func.c編譯出錯
在.h或者.cpp中定義的全局變量或者全局函數,理論上所有文件都可以直接調用,但是需要注意的是最好不要在.h中定義全局變量或者全局函數,一旦有多個文件include這個.h文件,那么就會出現多次定義的錯誤
比較合適的做法是:
對于全局變量而言,在.h中用extern聲明,在.c中定義
對于全局函數,在.h聲明,在.c定義
也可以直接在.c中定義全局變量,但是其他文件就不能直接調用了
http://blog.csdn.net/sunmenggmail/article/details/7568418
總結
以上是生活随笔為你收集整理的c/c++的全局变量的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: CUDA编程指南阅读笔记(六)
- 下一篇: s3c2440移植MQTT