一、帶參宏和帶參函數(shù)的區(qū)別(宏定義的缺陷)
- 宏定義在預(yù)處理期間處理戳粒,函數(shù)是在編譯期間處理力图。
- 宏定義最終在調(diào)用宏的地方把宏體原地展開(kāi),而函數(shù)是在調(diào)用函數(shù)處跳轉(zhuǎn)到函數(shù)中執(zhí)行尝丐,執(zhí)行完后再跳轉(zhuǎn)回來(lái)显拜。
- 宏定義是展開(kāi)沒(méi)有調(diào)用開(kāi)銷(xiāo),函數(shù)有調(diào)用開(kāi)銷(xiāo)爹袁。
- 當(dāng)函數(shù)體只有一句話(huà)時(shí)可以用宏定義替代远荠,這樣效率高。
- 宏定義不會(huì)檢查參數(shù)的類(lèi)型失息,返回值也不會(huì)附帶類(lèi)型譬淳。函數(shù)有明確的參數(shù)類(lèi)型和返回類(lèi)型,當(dāng)調(diào)用函數(shù)時(shí)編譯器會(huì)幫我們做靜態(tài)的類(lèi)型檢查盹兢,當(dāng)發(fā)現(xiàn)實(shí)際傳參和聲明的類(lèi)型不同時(shí)會(huì)報(bào)錯(cuò)邻梆。
- 用函數(shù)時(shí)不用太擔(dān)心類(lèi)型不匹配,編譯器會(huì)檢查蛤迎。但用宏時(shí)要注意類(lèi)型一致确虱,因?yàn)榫幾g器不會(huì)報(bào)錯(cuò),運(yùn)行就會(huì)直接出現(xiàn)錯(cuò)誤替裆。
- 宏和函數(shù)各有千秋校辩,如果代碼比較多窘问,比較適合用函數(shù)。對(duì)與只有一兩句話(huà)的函數(shù)(開(kāi)銷(xiāo)大)適合用帶參宏宜咒。但宏有缺點(diǎn):不檢查參數(shù)類(lèi)型惠赫。
#include <stdio.h>
#define MAX(a,b) (((a)>(b))?(a):(b))
int max(int a,int b)
{
if (a>b)
return a;
else
return b;
}
int main(void)
{
int a=3,b=5,c=0,d=0;
c=MAX(a,b);
printf("c=%d.\n,c");
d=max(a,b);
printf("d=%d.\n,c");
return 0;
}
二、內(nèi)聯(lián)函數(shù)和inline關(guān)鍵字
- 內(nèi)聯(lián)函數(shù):通過(guò)在函數(shù)定義前加inline關(guān)鍵字實(shí)現(xiàn)故黑。
- 內(nèi)聯(lián)函數(shù)本質(zhì)上是函數(shù)儿咱,有函數(shù)的優(yōu)點(diǎn)(內(nèi)聯(lián)函數(shù)由編譯器負(fù)責(zé)處理);同時(shí)又有帶參宏不用調(diào)用開(kāi)銷(xiāo)原地展開(kāi)的優(yōu)點(diǎn)场晶。
- 可以把內(nèi)聯(lián)函數(shù)看作是帶來(lái)參數(shù)靜態(tài)參數(shù)類(lèi)型檢查的宏混埠。
- 當(dāng)函數(shù)體很短,我們又利用編譯器的參數(shù)類(lèi)型檢查來(lái)排錯(cuò)诗轻,還希望沒(méi)有調(diào)用開(kāi)銷(xiāo)钳宪。此時(shí)最適合使用內(nèi)聯(lián)函數(shù)。
三扳炬、宏定義來(lái)實(shí)現(xiàn)條件編譯
- 程序由DEBUG和RELEASE版本,兩種區(qū)別是編譯時(shí)有無(wú)定義DEBUG宏,DEBUG版本可以用來(lái)做調(diào)試,RELEASE版本沒(méi)有調(diào)試過(guò)程提高運(yùn)行效率吏颖。
#include <stdio.h>
#define DEBUG
#undef DEBUG //注銷(xiāo)前面定義的宏
#ifdef DEBUG
#define debug(x) printf(x)
#else
#define debug(x)
#endif
int main(void)
{
debug("this is debug info.\n");
}