• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 10, comments - 1, trackbacks - 0, articles - 2

            C++內聯函數(Inline)

            Posted on 2009-05-31 21:50 Ben仔 閱讀(351) 評論(0)  編輯 收藏 引用 所屬分類: c++
             介紹內聯函數之前,有必要介紹一下預處理宏。內聯函數的功能和預處理宏的功能相似。相信大家都用過預處理宏,我們會經常定義一些宏,如 #define TABLE_COMP(x) ((x)>0?(x):0)   就定義了一個宏。   為什么要使用宏呢?因為函數的調用必須要將程序執行的順序轉移到函數所存放在內存中的某個地址,將函數的程序內容執行完后,再返回到轉去執行該函數前的地方。這種轉移操作要求在轉去執行前要保存現場并記憶執行的地址,轉回后要恢復現場,并按原來保存地址繼續執行。因此,函數調用要有一定的時間和空間方面的開銷,于是將影響其效率。而宏只是在預處理的地方把代碼展開,不需要額外的空間和時間方面的開銷,所以調用一個宏比調用一個函數更有效率。   但是宏也有很多的不盡人意的地方。   1、.宏不能訪問對象的私有成員。   2、.宏的定義很容易產生二意性。   我們舉個例子: #define TABLE_MULTI(x) (x*x)   我們用一個數字去調用它,TABLE_MULTI(10),這樣看上去沒有什么錯誤,結果返回100,是正確的,但是如果我們用TABLE_MULTI(10+10)去調用的話,我們期望的結果是400,而宏的調用結果是(10+10*10+10),結果是120,這顯然不是我們要得到的結果。避免這些錯誤的方法,一是給宏的參數都加上括號。 #define TABLE_MULTI(x) ((x)*(x))   這樣可以確保不會出錯,但是,即使使用了這種定義,這個宏依然有可能出錯,例如使用TABLE_MULTI(a++)調用它,他們本意是希望得到(a+1)*(a+1)的結果,而實際上呢?我們可以看看宏的展開結果: (a++)*(a++),如果a的值是4,我們得到的結果是5*6=30。而我們期望的結果是5*5=25,這又出現了問題。事實上,在一些C的庫函數中也有這些問題。例如: Toupper(*pChar++)就會對pChar執行兩次++操作,因為Toupper實際上也是一個宏。   我們可以看到宏有一些難以避免的問題,怎么解決呢?   下面就是用我要介紹的內聯函數來解決這些問題,我們可以使用內聯函數來取代宏的定義。而且事實上我們可以用內聯函數完全取代預處理宏。   內聯函數和宏的區別在于,宏是由預處理器對宏進行替代,而內聯函數是通過編譯器控制來實現的。而且內聯函數是真正的函數,只是在需要用到的時候,內聯函數像宏一樣的展開,所以取消了函數的參數壓棧,減少了調用的開銷。你可以象調用函數一樣來調用內聯函數,而不必擔心會產生于處理宏的一些問題。   我們可以用Inline來定義內聯函數,不過,任何在類的說明部分定義的函數都會被自動的認為是內聯函數。   下面我們來介紹一下內聯函數的用法。   內聯函數必須是和函數體申明在一起,才有效。像這樣的申明Inline Tablefunction(int I)是沒有效果的,編譯器只是把函數作為普通的函數申明,我們必須定義函數體。 Inline tablefunction(int I) {return I*I};   這樣我們才算定義了一個內聯函數。我們可以把它作為一般的函數一樣調用。但是執行速度確比一般函數的執行速度要快。   我們也可以將定義在類的外部的函數定義為內聯函數,比如: Class TableClass{  Private:   Int I,j;  Public:   Int add() { return I+j;};   Inline int dec() { return I-j;}   Int GetNum(); } inline int tableclass::GetNum(){ return I; }   上面申明的三個函數都是內聯函數。在C++中,在類的內部定義了函數體的函數,被默認為是內聯函數。而不管你是否有inline關鍵字。   內聯函數在C++類中,應用最廣的,應該是用來定義存取函數。我們定義的類中一般會把數據成員定義成私有的或者保護的,這樣,外界就不能直接讀寫我們類成員的數據了。對于私有或者保護成員的讀寫就必須使用成員接口函數來進行。如果我們把這些讀寫成員函數定義成內聯函數的話,將會獲得比較好的效率。 Class sample{  Private:   Int nTest;  Public:   Int readtest(){ return nTest;}  Void settest(int I) {nTest=I;} }   當然,內聯函數也有一定的局限性。就是函數中的執行代碼不能太多了,如果,內聯函數的函數體過大,一般的編譯器會放棄內聯方式,而采用普通的方式調用函數。這樣,內聯函數就和普通函數執行效率一樣了。
            94久久国产乱子伦精品免费| 伊人久久大香线蕉综合Av| 99精品久久精品| 精品国产青草久久久久福利| 性欧美大战久久久久久久| 久久久久亚洲AV成人网人人网站 | 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 久久无码人妻一区二区三区午夜 | 久久伊人亚洲AV无码网站| 三级三级久久三级久久| 久久精品国产亚洲AV无码娇色| 亚洲欧美精品伊人久久| 欧美精品国产综合久久| 伊人久久免费视频| 狠狠精品久久久无码中文字幕 | 久久国产精品成人片免费| 久久久久亚洲av毛片大| 国产精品无码久久久久久| 伊人久久大香线蕉无码麻豆| 91精品国产91久久| 久久综合综合久久综合| 综合久久给合久久狠狠狠97色| 成人久久精品一区二区三区| 久久天天躁夜夜躁狠狠躁2022| 久久成人精品| 欧美777精品久久久久网| 久久午夜无码鲁丝片| 久久久久久久波多野结衣高潮 | 色狠狠久久综合网| 国产免费福利体检区久久| 99久久亚洲综合精品网站| 久久久久人妻精品一区| 亚洲国产精品久久久天堂| 国内精品伊人久久久久妇| 亚洲&#228;v永久无码精品天堂久久 | 久久精品国产亚洲AV无码娇色| 久久精品aⅴ无码中文字字幕不卡 久久精品成人欧美大片 | 国产产无码乱码精品久久鸭| 久久亚洲AV成人无码国产| 人妻少妇久久中文字幕| 日韩人妻无码一区二区三区久久|