宏函数和函数的区别
轉載自:
http://www.ccidnet.com/2010/0709/2110463.shtml
1. 宏做的是簡單的字符串替換(注意是字符串的替換,不是其他類型參數的替換),而函數的參數的傳遞,參數是有數據類型的,可以是各種各樣的類型.
2. 宏的參數替換是不經計算而直接處理的,而函數調用是將實參的值傳遞給形參,既然說是值,自然是計算得來的.
3. 宏在編譯之前進行,即先用宏體替換宏名,然后再編譯的,而函數顯然是編譯之后,在執行時,才調用的.因此,宏占用的是編譯的時間,而函數占用的是執行時的時間.
4. 宏的參數是不占內存空間的,因為只是做字符串的替換,而函數調用時的參數傳遞則是具體變量之間的信息傳遞,形參作為函數的局部變量,顯然是占用內存的.
5. 函數的調用是需要付出一定的時空開銷的,因為系統在調用函數時,要保留現場,然后轉入被調用函數去執行,調用完,再返回主調函數,此時再恢復現場,這些操作,顯然在宏中是沒有的.
內聯函數: 所謂"內聯函數"就是將很簡單的函數"內嵌"到調用他的程序代碼中,只樣做的目的是為了避免上面說到的第5點,目的旨在節約下原本函數調用時的時空開銷. 但必須注意的是:作為內聯函數,函數體必須十分簡單,不能含有循環、條件、選擇等復雜的結構,否則就不能做為內聯函數了。事實上,即便你沒有指定函數為內 聯函數,有的編譯系統也會自動將很簡單的函數作為內聯函數處理;而對于復雜的函數,即便你指定他為內聯函數,系統也不會理會的。
函數和宏函數的區別就在于,宏函數占用了大量的空間,而函數占用了時間。大家要知道的是,函數調用是要使用系統的棧來保存數據的,如果編譯器里有棧檢查選 項,一般在函數的頭會嵌入一些匯編語句對當前棧進行檢查;同時,CPU也要在函數調用時保存和恢復當前的現場,進行壓棧和彈棧操作,所以,函數調用需要一 些CPU時間。 而宏函數不存在這個問題。宏函數僅僅作為預先寫好的代碼嵌入到當前程序,不會產生函數調用,所以僅僅是占用了空間,在頻繁調用同一個宏函數的時候,該現象 尤其突出。
?
轉載于:https://www.cnblogs.com/predator-wang/p/4816262.html
總結
- 上一篇: 计算机输入输出设计原则,交互设计精髓4中
- 下一篇: 【oracle灾备方案系列】基于DDS的