摘要:分析:tagMyStruct稱為“tag”,即“標(biāo)簽”,實(shí)際上是一個(gè)臨時(shí)名字,struct關(guān)鍵字和tagMyStruct一起,構(gòu)成了這個(gè)結(jié)構(gòu)類型,不論是否有typedef,這個(gè)結(jié)構(gòu)都存在。我們可以用structtagMyStructvarName來定義變量,但要注意,使用tagMyStructvarName來定義變量是不對(duì)的,因?yàn)閟truct和tagMyStruct合在一起才能表示一個(gè)結(jié)構(gòu)類型。2)typ
我們可以用struct tagMyStruct varName來定義變量,但要注意,使用tagMyStruct varName來定義變量是不對(duì)的,因?yàn)閟truct 和tagMyStruct合在一起才能表示一個(gè)結(jié)構(gòu)類型。
2) typedef為這個(gè)新的結(jié)構(gòu)起了一個(gè)名字,叫MyStruct。
typedef struct tagMyStruct MyStruct;
因此,MyStruct實(shí)際上相當(dāng)于struct tagMyStruct,我們可以使用MyStruct varName來定義變量。
答案與分析
C語言當(dāng)然允許在結(jié)構(gòu)中包含指向它自己的指針,我們可以在建立鏈表等數(shù)據(jù)結(jié)構(gòu)的實(shí)現(xiàn)上看到無數(shù)這樣的例子,上述代碼的根本問題在于typedef的應(yīng)用。
根據(jù)我們上面的闡述可以知道:新結(jié)構(gòu)建立的過程中遇到了pNext域的聲明,類型是pNode,要知道pNode表示的是類型的新名字,那么在類型本身還沒有建立完成的時(shí)候,這個(gè)類型的新名字也還不存在,也就是說這個(gè)時(shí)候編譯器根本不認(rèn)識(shí)pNode。
解決這個(gè)問題的方法有多種:
1)、
typedef struct tagNode
{
char *pItem;
struct tagNode *pNext;
} *pNode;
2)、
typedef struct tagNode *pNode;
struct tagNode
{
char *pItem;
pNode pNext;
};
注意:在這個(gè)例子中,你用typedef給一個(gè)還未完全聲明的類型起新名字。C語言編譯器支持這種做法。
3)、規(guī)范做法:
struct tagNode
{
char *pItem;
struct tagNode *pNext;
};
typedef struct tagNode *pNode;
[1] [2]
軟考備考資料免費(fèi)領(lǐng)取
去領(lǐng)取
共收錄117.93萬道題
已有25.02萬小伙伴參與做題