C++宏函數和內聯函數的使用
1. 宏常量&宏函數
1.1 定義
// a. 定義一個宏常量 #define MAX 1024 // 宏常量 MAX稱為符號常量 // b. 定義一個宏函數 // 宏函數:宏函數就是使用宏定義定義出來的函數,並不是真正意義上的函數。 #define GETSUM(x, y) ((x) + (y)) // 宏函數
1.2 使用宏函數的註意事項
- 要保證運算的完整性;
- 宏函數的使用場景:頻繁調用和短小的函數,封裝成宏函數;
- 使用宏函數的優點:以空間換時間;
2. 內聯函數
2.1 定義
內聯函數,C++獨有;
內聯函數本質也是一個普通的函數,解決瞭宏函數的缺陷;
// 內聯函數在函數聲明和函數定義上都要加上inline關鍵字。 inline int fun(); inline int fun() { cout << "fun..." << endl; }
2.2 某些情況編譯器不會做內聯編譯
- 不能存在任何形式的循環語句
- 不能存在過多的條件判斷語句
- 函數體不能過於龐大
- 不能對函數進行取地址的操作
3. 補充
3.1 宏定義和函數的區別
- 宏在預處理階段完成替換,之後被替換的文本參與編譯,相當於直接插入瞭代碼,運行時不存在函數調用,執行起來更快;函數調用在運行時需要跳轉到具體調用函數;
- 宏定義屬於在結構中插入代碼,沒有返回值;函數調用具有返回值;
- 宏定義參數沒有類型,不進行類型檢查;函數參數具有類型,需要檢查類型;
- 宏定義不要在最後加分號;
3.2 宏定義和typedef的區別
- 宏主要用於定義常量及書寫復雜的內容;typedef主要用於定義類型別名;
- 宏替換發生在預編譯階段之前,屬於文本插入替換;typedef是編譯的一部分;
- 宏不檢查類型;typedef會檢查數據類型;
- 宏不是語句,不在在最後加分號;typedef是語句,要加分號標識結束;
- 註意對指針的操作,typedef char * p_char和#define p_char char *區別巨大;
3.3 宏函數和內聯函數的區別
- 在使用時,宏隻做簡單字符串替換(編譯前)。而內聯函數可以進行參數類型檢查(編譯時),且具有返回值;
- 內聯函數在編譯時直接將函數代碼嵌入到目標代碼中,省去函數調用的開銷來提高執行效率,並且進行參數類型檢查,具有返回值,可以實現重載;
- 宏定義時要註意書寫(參數要括起來)否則容易出現歧義(保證運算的完整性),內聯函數不會產生歧義;
- 內聯函數有類型檢測、語法判斷等功能,而宏沒有;
3.4 define宏定義和const的區別
- 處理階段:define是在編譯的預處理階段起作用,而const是在編譯、運行的時候起作用;
- 安全性:
- define隻做替換,不做類型檢查和計算,也不求解,容易產生錯誤,一般最好加上一個大括號包含住全部的內容,要不然很容易出錯;
- const常量有數據類型,編譯器可以對其進行類型安全檢查;
- 內存占用
- define隻是將宏名稱進行替換,在內存中會產生多分相同的備份。const在程序運行中隻有一份備份,且可以執行常量折疊,能將復雜的的表達式計算出結果放入常量表
- 宏定義的數據沒有分配內存空間,隻是插入替換掉;const定義的變量隻是值不能改變,但要分配內存空間。
到此這篇關於C++宏函數和內聯函數的使用的文章就介紹到這瞭,更多相關C++宏函數和內聯函數內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- 詳解C++中typedef 和 #define 的區別
- 深入理解C++內聯函數
- 詳解C語言中typedef和#define的用法與區別
- C++ 引用與內聯函數詳情
- 詳解C++中的const和constexpr