c語言struct后面有指針 @數(shù)據(jù)結(jié)構(gòu)大神,這里為啥要定義兩個指針域呢?名字還不一樣?
@數(shù)據(jù)結(jié)構(gòu)大神,這里為啥要定義兩個指針域呢?名字還不一樣?Typedef struct node{int data struct node*next}stackenode,*linkstack Typ
@數(shù)據(jù)結(jié)構(gòu)大神,這里為啥要定義兩個指針域呢?名字還不一樣?
Typedef struct node{int data struct node*next}stackenode,*linkstack Typedef將2113定義為struct 5261類型,將linkstack定義為指向struct stackenode的指針類型。它們都是4102類型(與基本類1653 int等相同),當(dāng)然,它們可以用來定義變量。
至于為什么我們應(yīng)該使用struct node*next而不是stack node*next或linkstack next來定義指針字段,因為指針字段在上面定義,類型在下面定義。
定義指針字段時,stackenode和linkstack都不是類型。
學(xué)習(xí)c語言的時候指針應(yīng)該怎么理解?
簡而言之,指針是表示地址的無符號整數(shù)。
所以僅僅理解指針是不夠的。您還需要知道指針指向的數(shù)據(jù)空間是如何排列的。這可能涉及到一些與特定CPU/OS相關(guān)的知識。如果我們能用計算機體系結(jié)構(gòu)的知識來理解它,它會更深刻、更準(zhǔn)確。
例如:
如何存儲float/double/long double?
如何在數(shù)據(jù)空間中組織陣列?
字符串是如何存儲的?
如何存儲結(jié)構(gòu)和聯(lián)合體?
位域組織
具體CPU相關(guān)部分如下:
整數(shù)的存儲將涉及CPU大小的指定
浮點數(shù)的存儲直接關(guān)系到FPU的設(shè)計
此外,還有一些擴展知識,涉及內(nèi)存的分配和釋放:如何在程序中分配內(nèi)存?(malloc/free)
什么是堆和堆棧?
總而言之:指針是地址和整數(shù)。但要充分利用它,我們需要了解計算機存儲空間的分配。困難在這里,突破在這里。