C語言一般提供三種預(yù)處理功能:宏處理、文件包含、條件編譯。頭文件防衛(wèi)式申明中會(huì)用到條件編譯中 #ifndef
、#define
、#endif
的用法。所以,首先價(jià)紹下條件編譯。
1 條件編譯
一般情況下,在生成可執(zhí)行文件的過程中,源程序文件中的所有代碼行都進(jìn)行編譯,但是在一些跨操作系統(tǒng)的情況下,要求代碼既能在 Windows
下編譯運(yùn)行,也能在 Linux
下編譯運(yùn)行,因?yàn)樵诓煌牟僮飨到y(tǒng)下調(diào)用的某些函數(shù)只能在特定的操作系統(tǒng)編譯運(yùn)行,此時(shí)就需要使用條件編譯,讓部分代碼在滿足特定條件下編譯。
條件編譯的幾種格式
格式 1
#ifdef?標(biāo)識(shí)符
???程序段代碼1
#else
???程序段代碼2
#endif
作用:當(dāng)標(biāo)識(shí)符被定義過,則對(duì)程序段代碼 1 進(jìn)行編譯,否則對(duì)程序段 2 進(jìn)行編譯。
平時(shí),在進(jìn)行程序調(diào)試過程中,需要輸出一些信息方便調(diào)試,在調(diào)試結(jié)束后,不需要這些信息輸出,我們可以這樣處理:
#define?DEBUG
//然后在代碼中需要輸出調(diào)試信息的地方,寫一些輸出信息,例如:
#ifdef?DEBUG
???printf("調(diào)試需要輸出的提示信息\n");
#endif
格式 2
#ifndef?標(biāo)識(shí)符
????程序段代碼?1?
#else?
????程序段代碼?2
#endif
作用:若標(biāo)識(shí)符未被定義,則編譯程序段代碼 1,否則編譯程序段代碼 2。與格式 1 正好相反,RELEASE
模式與 DEBUG
模式正好相對(duì),所以格式 1 調(diào)試的例子也可以寫成這樣:
#define?RELEASE
//然后在代碼中需要輸出調(diào)試信息的地方,寫一些輸出信息,例如:
#ifndef?RELEASE
???printf("調(diào)試需要輸出的提示信息\n");
#endif
格式 3
#if?表達(dá)式
????程序段代碼?1
#else?if?表達(dá)式2
????程序段代碼?2
#else?
????程序段代碼?3
#endif???
跨平臺(tái)項(xiàng)目開發(fā),采用條件編譯可以同同一套代碼在不修改代碼的情況下在 Windows
平臺(tái)與 Linux
平臺(tái)編譯通過生成可執(zhí)行文件,增加代碼的可移植性。例如;
if?__Linux__
???//Linux專有函數(shù)代碼
#elif?_Win32
???//windows專有函數(shù)代碼
#else
???//其他平臺(tái)專有函數(shù)代碼
#endif
2 頭文件防衛(wèi)式聲明
在多文件包含的情況下,有些變量何你可能被直接的或者間接的重復(fù)定義,重復(fù) #include
的問題也可能發(fā)生,可以通過 #ifndef
、#define
、#endif
防衛(wèi)式聲明解決這一問題。
范例:
-
頭文件 head1.h 有如下定義:
int?g_head1?=?1;
-
頭文件 head2.h 有如下定義:
int?g_head2?=?2;
-
源文件 .cpp 中使用 g_head1
、g_head2
代碼如下:
#include?"head1.h"
#include?"head2.h"
#include?
using?namespace?std;
int?main()
{
???cout<???cout<???return?0;
}
-
隨著項(xiàng)目增大或者其他需求,可能出現(xiàn)頭文件的包含,例如頭文件 head2.h
中包含頭文件head1.h
,頭文件head2.h
如下:
#include?"head1.h";
int?g_head2?=?2;
此時(shí)編譯就會(huì)出現(xiàn)重復(fù)定義的錯(cuò)誤,這是因?yàn)樵次募?cpp 包含了頭文件 head1.h
、head2.h"
,head2.h
中也包含 head1.h
頭文件,所以head1.h
定義的 g_head1
被定義兩次。
-
頭文件 head1.h
防衛(wèi)式聲明改造
#ifndef?_HEAD1_
#define?_HEAD1_
int?g_head1?=?1;
#endif
-
頭文件 head2.h
防衛(wèi)式聲明改造
#ifndef?_HEAD2_
#define?_HEAD2_
#include?"head1.h"
int?g_head2?=?2;
#endif
修改后再次編譯,通過并成功執(zhí)行,使用#ifndef
、#define
、#endif
組合的防衛(wèi)式聲明,避免了頭文件內(nèi)容被多次 include
,所以在寫 .h 文件時(shí),要習(xí)慣性的使用文件防衛(wèi)式聲明。
另外,送四本算法小抄。
算法小抄是朋友 labuladong 寫的,他的新書《labuladong的算法小抄》出版了,恭喜他。這本書內(nèi)容源自于他 github 的一個(gè) 73k star 的項(xiàng)目,做技術(shù)的都明白 73k star 是啥概念。這本書手把手帶你刷算法題的,全彩色,四百多頁,干貨很多。作者用通俗易懂的語言講清楚了許多經(jīng)典的算法題目,很多題目都是在知名企業(yè)面試時(shí)候經(jīng)常遇到的,吃透之后肯定會(huì)增加你拿大廠 offer 的幾率。作者自己也是把國內(nèi)一線大廠的 offer 拿了個(gè)遍,簡直是一個(gè) offer 收割機(jī)了。算法難題時(shí)時(shí)有,唯有套路得人心,他把多年算法刷題的經(jīng)驗(yàn)給總結(jié)出套路,即學(xué)即用,非常實(shí)在。本書絕對(duì)可以幫助你掃清算法路上的障礙。當(dāng)當(dāng)這兩天還有優(yōu)惠,需要的趕緊買本看看吧:
免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺(tái)立場,如有問題,請(qǐng)聯(lián)系我們,謝謝!