[c/c++] typedef
和define
的區別
moakap
typedef和define都可以用來給物件取乙個別名,但是兩者卻有著很大不同。
1. 首先,二者執行時間不同
關鍵字typedef在編譯階段有效
,由於是在編譯階段,因此typedef有型別檢查的功能。
define則是巨集定義,發生在預處理階段,也就是編譯之前,它只進行簡單而機械的字串替換
,而不進行任何檢查。
#define用法例子:
#define f(x) x*x
main( )
程式的輸出結果是: 36,根本原因就在於#define只是簡單的字串替換。
2. 功能不同
typedef用來定義型別的別名,這些型別不只包含內部型別(int,char等),還包括自定義型別(如struct),可以起到使型別易於記憶的功能。
如: typedef int (*pf) (const char *, const char *);
定義乙個指向函式的指標的資料型別pf,其中函式返回值為int,引數為const char *。
typedef 有另外乙個重要的用途,那就是定義機器無關的型別,例如,你可以定義乙個叫 real 的浮點型別,在目標機器上它可以i獲得最高的精度:typedef long double real;
在不支援 long double 的機器上,該 typedef 看起來會是下面這樣:typedef double real;
並且,在連 double 都不支援的機器上,該 typedef 看起來會是這樣:typedef float real;
#define不只是可以為型別取別名,還可以定義常量、變數、編譯開關等。
3. 作用域不同
#define沒有作用域的限制,只要是之前預定義過的巨集,在以後的程式中都可以使用。
而typedef有自己的作用域。
void fun()
void gun()
4. 對指標的操作
二者修飾指標型別時,作用不同。
typedef int * pint;
#define pint int *
const pint p;//p不可更改,p指向的內容可以更改,相當於
int * const p;
const pint p;//p可以更改,p指向的內容不能更改,相當於
const int *p;或 int const *p;
pint s1, s2; //
s1和s2都是int型指標
pint s3, s4; //
相當於int * s3,s4;只有乙個是指標
。
c typedef 函式指標
c typedef 函式指標 函式指標 乙個函式在編譯時被分配乙個入口位址,將這個入口位址稱為函式的指標,可 以用乙個指標變數指向該函式指標,然後通過該變數來呼叫函式。有關說明 1 函式指標的宣告格式 函式返回值型別 指標變數名 引數型別列表 或者是 typedef 函式返回值型別 指標變數名 引數...
軟體 關於C,typedef
1 寫部落格能讓我慢下來,仔細思考 1 這篇部落格大多摘自網上 1 不管實在c還是c 中,typedef這個詞都不少見,當然出現頻率較高的還是在c 中。typedef與 define有些相似,但更多的是不同,特別是在一些複雜的用法上,就完全不同了,看了網上一些c c 的學習者的部落格,其中有一篇關於...
c typedef 無法前置宣告
為了減少c 檔案的編譯依賴,前置宣告經常使用,特別是在標頭檔案中,如果不是必要,對於class基本都使用前置宣告,而不是直接 include。今天遇到乙個問題,需要在某類的標頭檔案裡面引用到另外乙個 類 因此自然使用了前置宣告,但是居然編譯不過,顯示定義衝突。查了一下,原來被引用的 類 其實不是乙個...