第一遍看這本書的時候,稍微掃了一遍這個內(nèi)容,當(dāng)時看起來有時生硬,不是很懂,等于跳了過去了。現(xiàn)在再看,感覺很有用,也基本能看明白了。說個題外話,有時候看有些內(nèi)容,第一次看到的時候,覺得很難理解很難理解,就是反復(fù)看好幾遍也理解不了。那么不妨就放下這段內(nèi)容,也許你學(xué)過后面的內(nèi)容的后,有天你再返回來看當(dāng)初不懂的,就豁然開朗了,學(xué)習(xí)這本c++primer的過程中,真的有太多的這種體會了。
開始正題:
#define 指示的接受后面的名字,并把這個名字定義為預(yù)處理器變量,常用大寫。
#ifndef 字面意思就是if not define 如果沒有定義。就是如果后面的名字沒有被定義成預(yù)處理器變量,那么這句話后所有的程序都將被執(zhí)行,直到遇見#endif
說明具體用法和意義。
假如我自己寫了兩個頭文件one.h,和two.h。其中one.h包括的是一個類的定義;two.h由于也要用到這個類,所以這個頭文件里面必然要有一行程序:#include“one.h”。
而我們的主程序里面,開始必然要把我們自己定義的頭文件給加進去,必然應(yīng)該有兩行程序:#include“one.h”和#include“two.h”,這樣實際上one.h這個頭文件被包含了兩次,那個類的也相當(dāng)于定義了兩次,必然編譯時會出現(xiàn)錯誤,為了解決這個問題。在one.h里應(yīng)該加入這么一段程序:
#ifndef ONE
#define ONE
//這里應(yīng)是one.h里面本來應(yīng)該有的代碼程序
#endif
這樣這個頭文件在主程序處理時只會被處理一次。因為:當(dāng)主程序首先碰到這句::#include“one.h,時,由于是第一次處理one頭文件,ONE這個預(yù)處理器變量還沒有定義呢,所以會執(zhí)行#define ONE這個語句,ONE變量被定義了,頭文件one中的代碼也會被執(zhí)行了。當(dāng)主程序碰到這句:#include“two.h”,由于two頭文件中,也有這么一句:#include“one.h”,然后程序就會再次進入到one這個頭文件中執(zhí)行,這是由于ONE這個變量在第一次執(zhí)行one這個頭文件時已經(jīng)被定義了,所以#ifndef ONE判斷失敗,不會執(zhí)行后續(xù)的代碼了,也就不會在執(zhí)行one頭文件中實際有用的代碼了。這樣保證了頭文件只會被處理一次。
因此應(yīng)該在自己編寫的每個頭文件中都加上保護符,避免頭文件被多次包含。