編譯器處理不同
宏定義是一個“編譯時”概念,在預處理階段展開(在編譯時把所有用到宏定義值的地方用宏定義常量替換),不能對宏定義進行調試,生命周期結束於編譯時期;
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