先轉載下人家總結的宏和普通函數調用的區別:
(1)、宏只做簡單的字符串替換,函數是參數傳遞,所以必然有參數類型檢查(支持各種類型,而不是只有字符串)。
(2)、宏不經計算而直接替換參數,函數調用則是將參數表達式求值再傳遞給形參。
(3)、宏在編譯前進行,即先替換再編譯。而函數是編譯后,在執行時才調用的。宏占編譯時間,而函數占執行時間。
(4)、宏參數不占空間,因為只做字符串替換,而函數調用時參數傳遞是變量之間的傳遞,形參作為局部變量占內存空間。
(5)、函數調用需要保留現場,然后轉入調用函數執行,執行完畢再返回主調函數,這些耗費在宏中是沒有的。
使用宏和內聯函數都可以節省在函數調用方面的時間和空間開銷。二者都是為了提高效率,但是卻有著顯著的區別:
(1)、在使用時,宏只做簡單的預處理器符號表(字符串)中的簡單替換。而內聯函數可以進行參數類型檢查,且具有返回值(也能被強制轉換為可轉換的合適類型)。
(2)、內聯函數首先是函數,函數的許多性質都適用于內聯函數(如內聯函數可以重載)。
(3)、內聯函數可以作為某個類的成員函數,這樣可以使用類的保護成員和私有成員。而當一個表達式涉及到類保護成員或私有成員時,宏就不能實現了(無法將this指針放在合適位置)。
可以用內聯函數完全替代宏。
但是在使用內聯函數時也要注意:作為內聯函數,函數體必須十分簡單,不能包含循環,條件,選擇等復雜結構,否則不能作為內聯函數。
實際上,編譯器的優化系統會自動將一些簡單函數變成內聯函數。而一些復雜的函數,即使指定為內聯,編譯器也會自動當作普通函數。
文章出處:DIY部落(http://www.diybl.com/course/3_program/c++/cppxl/20081216/154041.html)