C++ 內(nèi)聯(lián)函數(shù)詳解
一、C++ 內(nèi)聯(lián)函數(shù)
1.內(nèi)聯(lián)
C 語言中有宏函數(shù)的概念。宏函數(shù)的特點(diǎn)是內(nèi)嵌到調(diào)用代碼中去,避免了函數(shù)調(diào)用的開銷。但是由于宏函數(shù)的處理發(fā)生在預(yù)處理階段,缺失了語法檢測和有可能帶來的語意差錯(cuò)。
2.語法
C++提供了 inline 關(guān)鍵字,實(shí)現(xiàn)了真正的內(nèi)嵌。
宏函數(shù) VS inline函數(shù)
#include <iostream>
#include <string.h>
using namespace std;
//優(yōu)點(diǎn):內(nèi)嵌代碼,辟免壓棧與出棧的開銷
//缺點(diǎn): 代碼替換,易使生成代碼體積變大,易產(chǎn)生邏輯錯(cuò)誤,無類型檢查
#define SQR(x) ((x)*(x))
//優(yōu)點(diǎn):高度抽象,避免重復(fù)開發(fā),類型檢查
//缺點(diǎn): 壓棧與出棧,帶來開銷
inline int sqr(int x)
{
return (x)*(x);
}
int main()
{
int i=0;
while(i<5)
{
printf("%d\n",SQR(i++));
printf("%d\n",i);
printf("%d\n",sqr(i++));
printf("%d\n",i);
}
return 0;
}

3.評價(jià)
引入內(nèi)聯(lián)函數(shù)的目的是為了解決程序中函數(shù)調(diào)用的效率問題,這么說吧,程序在編譯器編譯的時(shí)候,編譯器將程序中出現(xiàn)的內(nèi)聯(lián)函數(shù)的調(diào)用表達(dá)式用內(nèi)聯(lián)函數(shù)的函數(shù)體進(jìn)行替換,而對于其他的函數(shù),都是在運(yùn)行時(shí)候才被替代。這其實(shí)就是個(gè)空間代價(jià)換時(shí)間的i節(jié)省。所以內(nèi)聯(lián)函數(shù)一般都是1-5行的小函數(shù)。在使用內(nèi)聯(lián)函數(shù)時(shí)要留神:
1.在內(nèi)聯(lián)函數(shù)內(nèi)不允許使用循環(huán)語句和開關(guān)語句;
2.內(nèi)聯(lián)函數(shù)的定義必須出現(xiàn)在內(nèi)聯(lián)函數(shù)第一次調(diào)用之前;
3.類結(jié)構(gòu)中所在的類說明內(nèi)部定義的函數(shù)是內(nèi)聯(lián)函數(shù);
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
C++使用文件實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C++使用文件實(shí)現(xiàn)學(xué)生信息管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-01-01
C語言實(shí)現(xiàn)經(jīng)典掃雷小游戲的示例代碼
掃雷游戲是在一個(gè)指定的二維空間里,隨機(jī)布置雷,把不是雷的位置都找出來,在你點(diǎn)一個(gè)位置的時(shí)候它會(huì)顯示它周圍全部雷的個(gè)數(shù),根據(jù)這個(gè)線索去找 ,會(huì)更容易贏。本文將用C語言實(shí)現(xiàn)這一經(jīng)典游戲,感興趣的可以嘗試一下2022-11-11
C語言實(shí)現(xiàn)C++繼承和多態(tài)的代碼分享
本文主要給大家簡單講訴了C和C++的區(qū)別以及如何使用C語言模擬實(shí)現(xiàn)C++繼承和多態(tài),并附上示例代碼,是篇相當(dāng)不錯(cuò)的文章,推薦給喜歡C語言的小伙伴們2017-07-07
C++中使用哈希表(unordered_map)的一些常用操作方法
C++標(biāo)準(zhǔn)庫中使用的unordered_map底層實(shí)現(xiàn)是哈希表,下面這篇文章主要給大家介紹了關(guān)于C++中使用哈希表(unordered_map)的一些常用操作方法,需要的朋友可以參考下2022-03-03
詳解C++模擬實(shí)現(xiàn)priority_queue(仿函數(shù))
本文主要介紹了關(guān)于C++中優(yōu)先級(jí)隊(duì)列的模擬實(shí)現(xiàn),以及仿函數(shù)的使用,優(yōu)先級(jí)隊(duì)列是一種容器適配器,其第一個(gè)元素總是最大的,仿函數(shù)本質(zhì)是一個(gè)類,重載了operator(),可改變比較邏輯,同時(shí),文中還介紹了如何進(jìn)行類的比較,如日期類或其指針的比較,以及庫中sort函數(shù)的使用方法2024-10-10

