const(常量)和#define(宏定義)區別


編譯器處理不同

宏定義是一個“編譯時”概念,在預處理階段展開(在編譯時把所有用到宏定義值的地方用宏定義常量替換),不能對宏定義進行調試,生命周期結束於編譯時期;
const常量是一個“運行時”概念,在程序運行使用,類似於一個只讀行數據

存儲方式不同

宏定義是直接替換,不會分配內存,存儲與程序的代碼段中;
const常量需要進行內存分配

類型和安全檢查不同

宏定義是字符替換,沒有數據類型的區別,同時這種替換沒有類型安全檢查,可能產生邊際效應等錯誤;
const常量是常量的聲明,有類型區別,需要在編譯階段進行類型檢查

定義域不同

void f1 ()
{

    #define N 12
    const int n 12;
    
}

    void f2 ()
{
    cout<<N <<endl; //正確,N已經定義過,不受定義域限制
    cout<<n <<endl; //錯誤,n定義域只在f1函數中
}

是否可以做函數參數

宏定義不能作為參數傳遞給函數
const常量可以在函數的參數列表中出現

定義后能否取消

宏定義可以通過#undef來使之前的宏定義失效
const常量定義后將在定義域內永久有效

void f1()
{
  #define N 12
  const int n = 12;
  
  #undef N //取消宏定義后,即使在f1函數中,N也無效了
  #define N 21//取消后可以重新定義
}

總結

宏定義在編譯時把所有用到宏定義值的地方用宏定義常量替換。const常量可以看作是一個只讀變量,需要指定類型,需要分配內存,有自己的作用域。

參考博客

https://www.cnblogs.com/scut-linmaojiang/p/4722338.html

https://blog.csdn.net/weibo1230123/article/details/81981384

 


免責聲明!

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



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