關(guān)于c++的內(nèi)聯(lián)函數(shù)
(1)什么是內(nèi)聯(lián)函數(shù)?
(2)為什么要引入內(nèi)聯(lián)函數(shù)?
(3)為什么inline能取代宏?
(4)內(nèi)聯(lián)函數(shù)和宏的區(qū)別?
(5)什么時(shí)候用內(nèi)聯(lián)函數(shù)?
(6)如何使用內(nèi)聯(lián)函數(shù)?
(7)內(nèi)聯(lián)函數(shù)的優(yōu)缺點(diǎn)?
(8)如何禁止函數(shù)進(jìn)行內(nèi)聯(lián)?
(9)注意事項(xiàng):
(1)什么是內(nèi)聯(lián)函數(shù)? 內(nèi)聯(lián)函數(shù)是指那些定義在類(lèi)體內(nèi)的成員函數(shù),即該函數(shù)的函數(shù)體放在類(lèi)體內(nèi)。
(2)為什么要引入內(nèi)聯(lián)函數(shù)? 當(dāng)然,引入內(nèi)聯(lián)函數(shù)的主要目的是:解決程序中函數(shù)調(diào)用的效率問(wèn)題。另外,前面我們講到了宏,里面有這么一個(gè)例子: #define ABS(x) ((x)>0? (x):-(x)) 當(dāng)++i出現(xiàn)時(shí),宏就會(huì)歪曲我們的意思,換句話說(shuō)就是:宏的定義很容易產(chǎn)生二意性。 我們可以看到宏有一些難以避免的問(wèn)題,怎么解決呢?前面我們已經(jīng)盡力替換了。
下面我們用內(nèi)聯(lián)函數(shù)來(lái)解決這些問(wèn)題。
(3)為什么inline能取代宏? 1、 inline 定義的類(lèi)的內(nèi)聯(lián)函數(shù),函數(shù)的代碼被放入符號(hào)表中,在使用時(shí)直接進(jìn)行替換,(像宏一樣展開(kāi)),沒(méi)有了調(diào)用的開(kāi)銷(xiāo),效率也很高。 2、 很明顯,類(lèi)的內(nèi)聯(lián)函數(shù)也是一個(gè)真正的函數(shù),編譯器在調(diào)用一個(gè)內(nèi)聯(lián)函數(shù)時(shí),會(huì)首先檢查它的參數(shù)的類(lèi)型,保證調(diào)用正確。然后進(jìn)行一系列的相關(guān)檢查,就像對(duì)待任何一個(gè)真正的函數(shù)一樣。這樣就消除了它的隱患和局限性。 3、 inline 可以作為某個(gè)類(lèi)的成員函數(shù),當(dāng)然就可以在其中使用所在類(lèi)的保護(hù)成員及私有成員。
(4)內(nèi)聯(lián)函數(shù)和宏的區(qū)別? 內(nèi)聯(lián)函數(shù)和宏的區(qū)別在于,宏是由預(yù)處理器對(duì)宏進(jìn)行替代,而內(nèi)聯(lián)函數(shù)是通過(guò)編譯器控制來(lái)實(shí)現(xiàn)的。而且內(nèi)聯(lián)函數(shù)是真正的函數(shù),只是在需要用到的時(shí)候,內(nèi)聯(lián)函數(shù)像宏一樣的展開(kāi),所以取消了函數(shù)的參數(shù)壓棧,減少了調(diào)用的開(kāi)銷(xiāo)。你可以象調(diào)用函數(shù)一樣來(lái)調(diào)用內(nèi)聯(lián)函數(shù),而不必?fù)?dān)心會(huì)產(chǎn)生于處理宏的一些問(wèn)題。內(nèi)聯(lián)函數(shù)與帶參數(shù)的宏定義進(jìn)行下比較,它們的代碼效率是一樣,但是內(nèi)聯(lián)歡函數(shù)要優(yōu)于宏定義,因?yàn)閮?nèi)聯(lián)函數(shù)遵循的類(lèi)型和作用域規(guī)則,它與一般函數(shù)更相近,在一些編譯器中,一旦關(guān)上內(nèi)聯(lián)擴(kuò)展,將與一般函數(shù)一樣進(jìn)行調(diào)用,比較方便。
(5)什么時(shí)候用內(nèi)聯(lián)函數(shù)? 內(nèi)聯(lián)函數(shù)在C++類(lèi)中,應(yīng)用最廣的,應(yīng)該是用來(lái)定義存取函數(shù)。我們定義的類(lèi)中一般會(huì)把數(shù)據(jù)成員定義成私有的或者保護(hù)的,這樣,外界就不能直接讀寫(xiě)我們類(lèi)成員的數(shù)據(jù)了。對(duì)于私有或者保護(hù)成員的讀寫(xiě)就必須使用成員接口函數(shù)來(lái)進(jìn)行。如果我們把這些讀寫(xiě)成 員函數(shù)定義成內(nèi)聯(lián)函數(shù)的話,將會(huì)獲得比較好的效率。 Class A { Private: int nTest; Public: int readtest() { return nTest;} void settest(int I) { nTest=I; } }
(6)如何使用內(nèi)聯(lián)函數(shù)? 我們可以用inline來(lái)定義內(nèi)聯(lián)函數(shù)。 inline int A (int x) { return 2*x; } 不過(guò),任何在類(lèi)的說(shuō)明部分定義的函數(shù)都會(huì)被自動(dòng)的認(rèn)為是內(nèi)聯(lián)函數(shù)。
(7)內(nèi)聯(lián)函數(shù)的優(yōu)缺點(diǎn)? 我們可以把它作為一般的函數(shù)一樣調(diào)用,但是由于內(nèi)聯(lián)函數(shù)在需要的時(shí)候,會(huì)像宏一樣展開(kāi),所以執(zhí)行速度確比一般函數(shù)的執(zhí)行速度要快。當(dāng)然,內(nèi)聯(lián)函數(shù)也有一定的局限性。就是函數(shù)中的執(zhí)行代碼不能太多了,如果,內(nèi)聯(lián)函數(shù)的函數(shù)體過(guò)大,一般的編譯器會(huì)放棄內(nèi)聯(lián)方式,而采用普通的方式調(diào)用函數(shù)。(換句話說(shuō)就是,你使用內(nèi)聯(lián)函數(shù),只不過(guò)是向編譯器提出一個(gè)申請(qǐng),編譯器可以拒絕你的申請(qǐng))這樣,內(nèi)聯(lián)函數(shù)就和普通函數(shù)執(zhí)行效率一樣了。
(8)如何禁止函數(shù)進(jìn)行內(nèi)聯(lián)? 如果使用VC++,可以使用/Ob命令行參數(shù)。當(dāng)然,也可以在程序中使用 #pragma auto_inline達(dá)到相同的目的。
(9)注意事項(xiàng): 1.在內(nèi)聯(lián)函數(shù)內(nèi)不允許用循環(huán)語(yǔ)句和開(kāi)關(guān)語(yǔ)句。 2.內(nèi)聯(lián)函數(shù)的定義必須出現(xiàn)在內(nèi)聯(lián)函數(shù)第一次被調(diào)用之前。
|