可能不太熟悉,也有可能沒有去關(guān)心過。我們只關(guān)心程序能否正確運(yùn)行,或者程序怎么實(shí)現(xiàn)等等一些問題。
這里筆者就為介紹下我們熟悉又不太熟悉的“#include”,首先我們了解下C/C++頭文件。
頭文件為相關(guān)聲明提供了一個集中存在的位置。頭文件一般包含類的定義,extern變量聲明與函數(shù)聲明。注意這里聲明與定義的區(qū)別:它們最本質(zhì)的區(qū)別是定義只可以出現(xiàn)一次,聲明可以出現(xiàn)多次。聲明不分配空間,而定義是要分配空間的。頭文件正確使用可以保證所有文件使用給定實(shí)體的同一聲明;當(dāng)聲明需要修改時,只有頭文件需要更新。
頭文件還可以定義:在編譯的時候就已知道其值的cosnt對象和inline 函數(shù)。在頭文件中定義上述實(shí)體,是因?yàn)榫幾g器需要它們的定義來產(chǎn)生代碼。例如:為了產(chǎn)生能定義或使用類的對象代碼,編譯器需要知道組成該類型的數(shù)據(jù)成員,也需要知道對應(yīng)的函數(shù)。
在C++中,有些地方需要放置常量表達(dá)式。例如:枚舉成員的初始化必須是常量表達(dá)式。常量表達(dá)式是編譯器在編譯時就能夠在計(jì)算出結(jié)果的表達(dá)式。當(dāng)const整型變量通過常量表達(dá)式自我初始化時,這個const整型變量就可能是常量表達(dá)式。而const變量要成為常量表達(dá)式,初始化必須為編譯器可見。為了能夠讓多個文件使用相同的常量值,const變量和它的初始化必須是每個文件都可見的。所以將其定義放到頭文件中,無論const常量何時使用,編譯器都能知道其初始化。
#include是怎么樣工作的?
#include設(shè)施是C++預(yù)處理器的一部分。
預(yù)處理器處理程序的源代碼,是在編譯器之前運(yùn)行。
#include只接受一個參數(shù):頭文件名。
預(yù)處理器用指定的頭文件的內(nèi)容替代每個include。
我們自己的頭文件存儲在文件中。系統(tǒng)的頭文件可能用特定于編譯器的更高效的格式保存。
頭文件經(jīng)常#include其他頭文件。頭文件定義的實(shí)體經(jīng)常使用在其他文件的設(shè)施。所以設(shè)計(jì)的頭文件時,應(yīng)使其可以多次包含在同一源文件中。我們必須保證包含同一頭文件不會引起該頭文件定義的類和對象被多次定義。使得頭文件安全的通過做法,使用預(yù)處理器定義頭文件保護(hù)符。
什么是頭文件保護(hù)符?
看看下面內(nèi)容大家就會明白了
在編寫頭文件之前,我們需要引入一些額外的預(yù)處理器設(shè)施。預(yù)處理器允許我們自定義變量。為了避免名字沖突,預(yù)處理器變量經(jīng)常用全大寫字母表示。預(yù)處理變量有兩種狀態(tài):已定義或未定義。
復(fù)制代碼 代碼如下:
#ifndef BEGEIN_H
#define BEGEIN_H
//定義一些類或者定義函數(shù)
#endif
如果沒有兩個頭文件定義和使用相同的預(yù)處理器變量,那么就沒有問題。如果出現(xiàn)上述情況,可以用定義在頭文件里實(shí)體類來命名預(yù)處理器變量來避免預(yù)處理變量重名問題。
#include <>與#include " "區(qū)別
如果頭文件名在<>中,就會被認(rèn)為是標(biāo)準(zhǔn)頭文件。編譯器會在預(yù)定義的位置查找該頭文件,如果是""就認(rèn)為它是非系統(tǒng)頭文件,非系統(tǒng)文件查找通常開始于源文件所在路徑。