其實咱們早就有接觸文件包含這個指令了, 就是#include,它能夠將一個文件的所有內容拷貝另外一個文件中。函數
直接到C語言庫函數頭文件所在的目錄中尋找文件spa
系統會先在源程序當前目錄下尋找,若找不到,再到操做系統的path路徑中查找,最後纔到C語言庫函數頭文件所在目錄中查找操作系統
1.#include指令容許嵌套包含,好比a.h包含b.h,b.h包含c.h,可是不容許遞歸包含,好比 a.h 包含 b.h,b.h 包含 a.h。code
下面的作法是錯誤的orm
2.使用#include指令可能致使屢次包含同一個頭文件,下降編譯效率
遞歸
好比下面的狀況:it
在one.h中聲明瞭一個one函數;在two.h中包含了one.h,順便聲明瞭一個two函數。(這裏就不寫函數的實現了,也就是函數的定義)編譯
假如我想在main.c中使用one和two兩個函數,並且有時候咱們並不必定知道two.h中包含了one.h,因此可能會這樣作:class
編譯預處理以後main.c的代碼是這樣的:效率
1 void one(); 2 void one(); 3 void two(); 4 int main () { return 0; }
第1行是由#include "one.h"致使的,第二、3行是由#include "two.h"致使的(由於two.h裏面包含了one.h)。能夠看出來,one函數被聲明瞭2遍,根本就沒有必要,這樣會下降編譯效率。
爲了解決這種重複包含同一個頭文件的問題,通常咱們會這樣寫頭文件內容:
大體解釋一下意思,就拿one.h爲例:當咱們第一次#include "one.h"時,由於沒有定義_ONE_H_,因此第9行的條件成立,接着在第10行定義了_ONE_H_這個宏,而後在13行聲明one函數,最後在15行結束條件編譯。當第二次#include "one.h",由於以前已經定義過_ONE_H_這個宏,因此第9行的條件不成立,直接跳到第15行的#endif,結束條件編譯。就是這麼簡單的3句代碼,防止了one.h的內容被重複包含。
這樣子的話,main.c中的:
#include "one.h" #include "two.h"
就變成了:
// #include "one.h" #ifndef _ONE_H_ #define _ONE_H_ void one(); #endif // #include "two.h" #ifndef _TWO_H_ #define _TWO_H_ // #include "one.h" #ifndef _ONE_H_ #define _ONE_H_ void one(); #endif void two(); #endif
第2~第7行是#include "one.h"致使的,第10~第23行是#include "two.h"致使的。編譯預處理以後就變爲了:
1 void one(); 2 void two();
這纔是咱們想要的結果