解決C/C++語言中全局變量重復定義的問題
阿新 • • 發佈:2018-01-27
分離 sta 9.png 代碼 extern 不同 遇到 情況 而且
前言
今天,在整理自己的代碼的時候,考慮到我寫的代碼從一至終都是在一個cpp文件裏面。於是,想把自己的代碼中的各個模塊分離開來,以便更好地閱讀和管理。
遇到的問題
我的做法是:
- 宏定義、結構體定義、函數聲明以及全局變量定義放到一個head.h頭文件中
- 函數的定義放到head.cpp中
- main函數放到main.cpp中
然而卻報錯了,提示xxx變量在*.obj文件中已定義
問題出現的原因
為什麽會出現這種情況呢?
- 首先單個文件的編譯是獨立的。在head.cpp編譯到head.obj,main.cpp編譯到main.obj。這個過程沒有報錯,也就是說明編譯過程是沒有問題的。
- 接下來是obj的鏈接。在鏈接main.obj與head.obj的時候,此時編譯器發現head.obj為這些全局變量分配了內存空間,而在main.obj中也為這些全局變量分配了內存空間。
- 同樣一個變量卻出現了兩個不同的內存地址。於是編譯器報錯。
不是辦法的辦法
把head.h裏面的頭文件的全局變量都加上static。編譯便可通過,可是卻會不經意出現了其他問題。
static只是把變量的生存周期延長,同時也把該變量限定於當前的文件。而之所以能用於main.cpp中,是因為在編譯的時候復制了一個變量名相同的變量給main.cpp而已。那麽main.cpp裏面的“全局變量”的改變,並不能改變原來head.h裏面的全局變量的值。
這樣子雖然編譯通過了,但是程序是錯誤的。
真正的解決方法
- 把全局變量定義放到head.cpp文件中。
- 在head.h存放全局變量的聲明,同時每個聲明前用
extern
我的個人想法
我覺得為了能更加分離全局變量,可以做的一個做法是:
- 全局變量定義依舊放在head.cpp中。
- 新建一個global.h的頭文件,存放全局變量的聲明,同時每個聲明前用
extern
去修飾。 - 在其他文件需要用到全局變量的時候,將global.h頭文件#include進來。
結言
這個問題的出現,很大原因是C語言太久沒有使用過了。而且,在使用c語言或者c++語言的時候,往往因為實驗以及課設所需要寫的代碼不太多,於是養成了一種習慣,一個main.cpp寫到結尾。當真正自己去分離自己的模塊代碼的時候,發現因為定義的全局變量導致編譯鏈接出現錯誤,實屬不該。故寫下此文警惕自己!文中可能有不對的地方,希望大家能指正!
文章出自kwongtai‘blog,轉載請標明出處
解決C/C++語言中全局變量重復定義的問題