define
常見用法:
1.定義簡單的常數:定義常量,便於修改(切不可在後面加上分號!)
#define n 1000
等效於
constint n = 1000;
但略有不同,define只是簡單替換,而不是作為乙個變數來使用.
2. 定義簡單的函式:注意多使用括號 define可以像函式那樣接受一些引數,如下:
#define max(x,y) (x)>(y)?(x):(y);
3.條件編譯(防止重複包括 重複定義)
4.定義單行巨集,多行巨集
與const比較部分
關於const的詳解見先下表
援引自: 1
可以定義const常量
const int max = 100;
2便於進行型別檢查
const常量有資料型別,而巨集常量沒有資料型別。編譯器可以對前者進行型別安全檢查,而對後者只進行字元替換,沒有型別安全檢查,並且在字元替換時可能會產生意料不到的錯誤
void f(const int i) //對傳入的引數進行型別檢查,不匹配進行提示
3可以保護被修飾的東西
防止意外的修改,增強程式的健壯性。
void f(const int i) //如果在函式體內修改了i,編譯器就會報錯
4可以很方便地進行引數的調整和修改
同巨集定義一樣,可以做到不變則已,一變都變
5為函式過載提供了乙個參考
class a //乙個函式 void f(int i) const //上乙個函式的過載 ...... };
6可以節省空間,避免不必要的記憶體分配
const定義常量從彙編的角度來看,只是給出了對應的記憶體位址,而不是象#define一樣給出的是立即數,所以,const定義的常量在程式執行過程中只有乙份拷貝,而#define定義的常量在記憶體中有若干個拷貝
#define pi 3.14159 //常量巨集 const doulbe pi=3.14159; //此時並未將pi放入rom中 ...... double i=pi; //此時為pi分配記憶體,以後不再分配! double i=pi; //編譯期間進行巨集替換,分配記憶體 double j=pi; //沒有記憶體分配 double j=pi; //再進行巨集替換,又一次分配記憶體!
7提高了效率
編譯器通常不為普通const常量分配儲存空間,而是將它們儲存在符號表中,這使得它成為乙個編譯期間的常量,沒有了儲存與讀記憶體的操作,使得它的效率也很高
C 中const和 define的對比
const常量分配記憶體的時機 編譯器編譯期間。第一種情況,當沒有對const修飾的常量進行取位址或其它檔案也沒使用此常量時,不會對const常量分配記憶體。include include int main 輸出結果 可以看出,變數a和c的位址是連續的,並沒有給常量b分配記憶體。第二種情況,對con...
define與const的區別
define 定義的其實是乙個字面常量的名字,在程式中可以把這個名字等價於字面常量使用,在編譯時會被編譯器替換為該字面常量。使用這種方式,只能達到提高程式可讀性的效果,但是安全性不能得到保證。從const 語句的語法格式可以看出,const 語句支援為常量指定型別,編譯器在編譯 時將其型別進行安全檢...
const 與 define的區別
在c程式中,const的用法主要有定義常量 修飾函式引數 修飾函式返回值等3個用處 在c 程式中,它還可以修飾函式的定義體,定義類中某個成員函式為恆態函式,即不改變類中的資料成員 1 const 有資料型別,而巨集沒有資料型別,編譯器可以對前者進行型別安全檢查,而對後者只進行字元替換,沒有型別安全檢...