C語言基礎-09-預處理指令3-文件包含

1、基本概念

其實咱們早就有接觸文件包含這個指令了, 就是#include,它能夠將一個文件的所有內容拷貝另外一個文件中。函數

2、通常形式

1.第1種形式#include <文件名>

直接到C語言庫函數頭文件所在的目錄中尋找文件spa

 

2.第2種形式 #include "文件名"

系統會先在源程序當前目錄下尋找,若找不到,再到操做系統的path路徑中查找,最後纔到C語言庫函數頭文件所在目錄中查找操作系統

3、使用注意

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();

這纔是咱們想要的結果

相關文章
相關標籤/搜索