typedef的用法以及與define 的區別

2021-06-16 13:32:22 字數 3367 閱讀 6870

typedef為c語言的關鍵字,作用是為一種資料型別定義乙個新名字。這裡的資料型別包括內部資料型別(int,char等)和自定義的資料型別(struct等)。

在程式設計中使用typedef目的一般有兩個,乙個是給變數乙個易記且意義明確的新名字,另乙個是簡化一些比較複雜的型別宣告。

至於typedef有什麼微妙之處,請你接著看下面對幾個問題的具體闡述。

2. typedef & 結構的問題

當用下面的**定義乙個結構時,編譯器報了乙個錯誤,為什麼呢?莫非c語言不允許在結構中包含指向它自己的指標嗎?請你先猜想一下,然後看下文說明:

typedef struct tagnode

char *pitem;

pnode pnext;

} *pnode;

分析:1、typedef的最簡單使用

typedef long byte_4;

給已知資料型別long起個新名字,叫byte_4。

2、 typedef與結構結合使用

typedef struct tagmystruct

int inum;

long llength;

} mystruct;

這語句實際上完成兩個操作:

1) 定義乙個新的結構型別

struct tagmystruct

int inum;

long llength;

分析:tagmystruct稱為「tag」,即「標籤」,實際上是乙個臨時名字,struct關鍵字和tagmystruct一起,構成了這個結構型別,不論是否有typedef,這個結構都存在。

我們可以用struct tagmystruct varname來定義變數,但要注意,使用tagmystruct varname來定義變數是不對的,因為struct 和tagmystruct合在一起才能表示乙個結構型別。

2) typedef為這個新的結構起了乙個名字,叫mystruct。

typedef struct tagmystruct mystruct;

因此,mystruct實際上相當於struct tagmystruct,我們可以使用mystruct varname來定義變數。

答案與分析

c語言當然允許在結構中包含指向它自己的指標,我們可以在建立鍊錶等資料結構的實現上看到無數這樣的例子,上述**的根本問題在於typedef的應用。

根據我們上面的闡述可以知道:新結構建立的過程中遇到了pnext域的宣告,型別是pnode,要知道pnode表示的是型別的新名字,那麼在型別本身還沒有建立完成的時候,這個型別的新名字也還不存在,也就是說這個時候編譯器根本不認識pnode。

解決這個問題的方法有多種:

1)、typedef struct tagnode

char *pitem;

struct tagnode *pnext;

} *pnode;

2)、typedef struct tagnode *pnode;

struct tagnode

char *pitem;

pnode pnext;

注意:在這個例子中,你用typedef給乙個還未完全宣告的型別起新名字。c語言編譯器支援這種做法。

3)、規範做法:

struct tagnode

char *pitem;

struct tagnode *pnext;

typedef struct tagnode *pnode;

3. typedef & #define的問題

有下面兩種定義pstr資料型別的方法,兩者有什麼不同?哪一種更好一點?

typedef char* pstr;

#define pstr char*;

答案與分析:

通常講,typedef要比#define要好,特別是在有指標的場合。請看例子:

typedef char* pstr1;

#define pstr2 char *

pstr1 s1, s2;

pstr2 s3, s4;

在上述的變數定義中,s1、s2、s3都被定義為char *,而s4則定義成了char,不是我們所預期的指標變數,根本原因就在於#define只是簡單的字串替換而typedef則是為乙個型別起新名字。

上例中define語句必須寫成 pstr2 s3, *s4; 這這樣才能正常執行。

#define用法例子:

#define f(x) x*x

main( )

int a=6,b=2,c;

c=f(a) / f(b);

printf("%d \\n",c);

以下程式的輸出結果是: 36。       6*6/2*2 = 36

因為如此原因,在許多c語言程式設計規範中提到使用#define定義時,如果定義中包含表示式,必須使用括號,則上述定義應該如下定義才對:

#define f(x) (x*x)    

當然,如果你使用typedef就沒有這樣的問題。

4. typedef & #define的另一例

下面的**中編譯器會報乙個錯誤,你知道是哪個語句錯了嗎?

typedef char * pstr;

char string[4] = "abc";

const char *p1 = string;

const pstr p2 = string;

p1++;

p2++;

答案與分析:

是p2++出錯了。這個問題再一次提醒我們:typedef和#define不同,它不是簡單的文字替換。上述**中const pstr p2並不等於const char * p2。const pstr p2和const long x本質上沒有區別,都是對變數進行唯讀限制,只不過此處變數p2的資料型別是我們自己定義的而不是系統固有型別而已。因此,const pstr p2的含義是:限定資料型別為char *的變數p2為唯讀,因此p2++錯誤。

4. typedef & #define的另一例

下面的**中編譯器會報乙個錯誤,你知道是哪個語句錯了嗎?

typedef char * pstr;

char string[4] = "abc";

const char *p1 = string;

const pstr p2 = string;

p1++;

p2++;

答案與分析:

是p2++出錯了。這個問題再一次提醒我們:typedef和#define不同,它不是簡單的文字替換。上述**中const pstr p2並不等於const char * p2。const pstr p2和const long x本質上沒有區別,都是對變數進行唯讀限制,只不過此處變數p2的資料型別是我們自己定義的而不是系統固有型別而已。因此,const pstr p2的含義是:限定資料型別為char *的變數p2為唯讀,因此p2++錯誤。

typedef和 define的用法以及區別

一 typedef的用法 在c c 語言中,typedef常用來定義乙個識別符號及關鍵字的別名,它是語言編譯過程的一部分,但它並不實際分配記憶體空間,例項像 typedef int int typedef int array 10 typedef int pint typedef可以增強程式的可讀性...

typedef 用法與陷阱

首先來看乙個宣告 typedef int myfunc const char const struct stat int 怎麼理解吶?myfunc const char const struct stat int 是int,是不是有點問題。這就是對typedef的理解出了問題。之前見到的都是type...

typedef 與函式指標的用法

在網上搜尋函式指標,看到乙個例子。開始沒看懂,想放棄,可是轉念一想,這個用法遲早要弄懂的,現在多花點時間看懂它,好過以後碰到了要再花一倍時間來弄懂它。其實很多時候都是這樣,如果每次到難一點的內容,總想著下次我再來解決它,那就永遠也學不到東西。後面那個例子加了注釋,是我對這種用法的理解,希望對新手有所...