內聯函數與普通函數的區別


內聯函數的執行過程與帶參數宏定義很相似,但參數的處理不同。帶參數的宏定義並不對參數進行運算,而是直接替換;內聯函數首先是函數,這就意味着函數的很多性質都適用於內聯函數,即內聯函數先把參數表達式進行運算求值,然后把表達式的值傳遞給形式參數。

內聯函數與帶參數宏定義的另一個區別是,內聯函數的參數類型和返回值類型在聲明中都有明確的指定;而帶參數宏定義的參數沒有類型的概念,只有在宏展開以后,才由編譯器檢查語法,這就存在很多的安全隱患。

使用內聯函數時,應注意的問題:

  1)內聯函數的定義性聲明應該出現在對該函數的第一次調用之前。

  2)內聯函數首先是函數,函數的很多性質都適用於內聯函數,如內聯函數可以重載。

  3)在內聯函數中不允許使用循環語句和switch結果,帶有異常接口聲明的函數也不能聲明為內聯函數。

宏和函數的區別:

  1. 宏做的是簡單的字符串替換(注意是字符串的替換,不是其他類型參數的替換),而函數的參數的傳遞,參數是有數據類型的,可以是各種各樣的類型。

  2. 宏的參數替換是不經計算而直接處理的,而函數調用是將實參的值傳遞給形參,既然說是值,自然是計算得來的。

  3. 宏在編譯之前進行,即先用宏體替換宏名,然后再編譯的,而函數顯然是編譯之后,在執行時,才調用的。因此,宏占用的是編譯的時間,而函數占用的是執行時的時間。

  4. 宏的參數是不占內存空間的,因為只是做字符串的替換,而函數調用時的參數傳遞則是具體變量之間的信息傳遞,形參作為函數的局部變量,顯然是占用內存的。

  5. 函數的調用是需要付出一定的時空開銷的,因為系統在調用函數時,要保留現場,然后轉入被調用函數去執行,調用完,再返回主調函數,此時再恢復現場,這些操作,顯然在宏中是沒有的。

內聯函數

所謂“內聯函數”就是將很簡單的函數“內嵌”到調用他的程序代碼中,只樣做的目的是為了避免上面說到的第5點,目的旨在節約下原本函數調用時的時空開銷。但必須注意的是:作為內聯函數,函數體必須十分簡單,不能含有循環、條件、選擇等復雜的結構,否則就不能做為內聯函數了。事實上,即便你沒有指定函數為內聯函數,有的編譯系統也會自動將很簡單的函數作為內聯函數處理;而對於復雜的函數,即便你指定他為內聯函數,系統也不會理會的。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM