在C++的程序的編寫過程中,基本上都碰到過LNK2005的錯誤吧,下面就針對這個問題詳細分析:
首先,預處理階段:
這一過程,主要針對#include和#define進行處理,具體過程如下:
對于cpp文件中經常會出現#include來包含某個頭文件,在進行預處理之后,所有的#include命令都將替換成該頭文件中的詳細內容,如果該頭文件中還包含另外的頭文件,采用同樣的方法進行遞歸處理。同樣#define亦是如此,對用它進行宏定義的字符進行替換,這里就是簡單的替換。所以整個預處理過程就是進行簡單的替換。
其次,預編譯過程
這一過程主要針對預處理之后的cpp文件編譯稱為obj文件,即目標文件(注意,在這里僅僅是針對cpp文件,對頭文件是不做任何處理的,所以在多文件工程中定義全局變量的時候,我們一定要記得把全局變量定義在cpp文件中,因為如果定義在頭文件中,我們要使用該變量的話很容易出現already define的錯誤)。主要是通過編譯器和匯編器生成二進制文件,便于鏈接處理。
對于這個,我給個實例和其解釋:
在鏈接的過程中,用extern申明的變量,我們很明確的知道這是一個外部變量,那么對于此,連接器會到外部的obj文件中區尋找該變量,如果說是我們在該obj文件編譯的cpp中有該變量的定義的話,那么這就不是一個聲明了,而是一個定義。所以,我們的這個obj文件編譯的源文件cpp,千萬不要包含有該變量定義的頭文件或者cpp文件,否則就是重定義,也就是說有些重定義是在鏈接的時候才會確定的一個錯誤,所以最好是在.h文件中用extern進行聲明,然后再隨便一個cpp文件中進行定義。在你想要使用該變量的cpp文件中只需要包含該頭文件即可。
第三,鏈接過程
如果寫程序中沒有足夠的警覺,在這個過程中極易出現鏈接錯誤。首先該過程主要是將眾多的obj文件生成exe文件。
首先,預處理階段:
這一過程,主要針對#include和#define進行處理,具體過程如下:
對于cpp文件中經常會出現#include來包含某個頭文件,在進行預處理之后,所有的#include命令都將替換成該頭文件中的詳細內容,如果該頭文件中還包含另外的頭文件,采用同樣的方法進行遞歸處理。同樣#define亦是如此,對用它進行宏定義的字符進行替換,這里就是簡單的替換。所以整個預處理過程就是進行簡單的替換。
其次,預編譯過程
這一過程主要針對預處理之后的cpp文件編譯稱為obj文件,即目標文件(注意,在這里僅僅是針對cpp文件,對頭文件是不做任何處理的,所以在多文件工程中定義全局變量的時候,我們一定要記得把全局變量定義在cpp文件中,因為如果定義在頭文件中,我們要使用該變量的話很容易出現already define的錯誤)。主要是通過編譯器和匯編器生成二進制文件,便于鏈接處理。
對于這個,我給個實例和其解釋:
在鏈接的過程中,用extern申明的變量,我們很明確的知道這是一個外部變量,那么對于此,連接器會到外部的obj文件中區尋找該變量,如果說是我們在該obj文件編譯的cpp中有該變量的定義的話,那么這就不是一個聲明了,而是一個定義。所以,我們的這個obj文件編譯的源文件cpp,千萬不要包含有該變量定義的頭文件或者cpp文件,否則就是重定義,也就是說有些重定義是在鏈接的時候才會確定的一個錯誤,所以最好是在.h文件中用extern進行聲明,然后再隨便一個cpp文件中進行定義。在你想要使用該變量的cpp文件中只需要包含該頭文件即可。
第三,鏈接過程
如果寫程序中沒有足夠的警覺,在這個過程中極易出現鏈接錯誤。首先該過程主要是將眾多的obj文件生成exe文件。