宏、函數和宏函數的區別?

來源:互聯網
上載者:User

先說宏和函數的區別
1. 宏做的是簡單的字串替換(注意是字串的替換,不是其他型別參數的替換),而函數的參數的傳遞,參數是有資料類型的,可以是各種各樣的類型.
2. 宏的參數替換是不經計算而直接處理的,而函數調用是將實參的值傳遞給形參,既然說是值,自然是計算得來的.
3. 宏在編譯之前進行,即先用宏體替換宏名,然後再編譯的,而函數顯然是編譯之後,在執行時,才調用的.因此,宏佔用的是編譯的時間,而函數佔用的是執行時的時間.
4. 宏的參數是不佔記憶體空間的,因為只是做字串的替換,而函數調用時的參數傳遞則是具體變數之間的資訊傳遞,形參作為函數的局部變數,顯然是佔用記憶體的.
5. 函數的調用是需要付出一定的時空開銷的,因為系統在調用函數時,要保留現場,然後轉入被調用函數去執行,調用完,再返回主調函數,此時再恢複現場,這些操作,顯然在宏中是沒有的.
  現在來看內嵌函式:
所謂"內嵌函式"就是將很簡單的函數"內嵌"到調用他的程式碼中,只樣做的目的是為了避免上面說到的第5點,目的旨在節約下原本函數調用時的時空開銷.但必須注意的是:作為內嵌函式,函數體必須十分簡單,不能含有迴圈、條件、選擇等複雜的結構,否則就不能做為內嵌函式了。事實上,即便你沒有指定函數為內嵌函式,有的編譯系統也會自動將很簡單的函數作為內嵌函式處理;而對於複雜的函數,即便你指定他為內嵌函式,系統也不會理會的。

 

函數和宏函數的區別就在於,宏函數佔用了大量的空間,而函數佔用了時間。大家要知道的是,函數調用是要使用系統的棧來儲存資料的,如果編譯器裡有棧檢查選項,一般在函數的頭會嵌入一些彙編語句對當前棧進行檢查;同時,CPU也要在函數調用時儲存和恢複當前的現場,進行壓棧和彈棧操作,所以,函數調用需要一些CPU時間。

而宏函數不存在這個問題。宏函數僅僅作為預先寫好的代碼嵌入到當前程式,不會產生函數調用,所以僅僅是佔用了空間,在頻繁調用同一個宏函數的時候,該現象尤其突出。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.