C++-Typedef结构体遇上指针

  继Typedef遇上结构体数组后,我们又产生了新的疑问。

  上一期地址:https://www.cnblogs.com/lemaden/p/10122929.html  

  昨天一位朋友又问我了,说结构体数组遇上typedef我懂了,就是数组拥有三个特性:1.首地址 2.数组的长度 3. 数组的步长(元素类型),typedef只是重定义了数组的长度和类型。

  那么今天的typedef跟结构体指针你怎么解释呢?我们看下问题的代码:

typedef struct LNode
{                                                      // Singly linked list Node
     int    data; 
     struct LNode   *next;                   // Pointer to next node
}LNode,*LinkList;            

  在链表中定义节点时,经常会看到上面的第四行,strcut LNode *next,这里仿佛是在边定义节点类型,又在里面定义指针域,其实这样是可以的,记住:在C语言中,只有这里可以这样用,其他地方都不可以,而且只能是指针,不能是结构体变量,否则会陷入无限递归。

  第三行就不用解释了,一个数据域。那么三四行我们都解决了。继续往下走。

  第五行右括号 { 第一个类型LNode比较好解释。

  是为struct LNode 创建一个简单的别名,以后就用LNode代替它了。

  那么*LinkList呢?

  我们把它单纯拿出来:

typedef struct LNode
{                                                      // Singly linked list Node
     int    data; 
     struct LNode   *next;                   // Pointer to next node
}*LinkList;  

  一句话解释清楚:把* 与前面的struct LNode放在一起,是不是就清楚了?

typedef struct LNode {....}*     LinkList 

  我们可以拿基本类型来示范下:

typedef int* Pointer;
Pointer p;    //指向整型类型的指针P

  那么回到上面的例子,LinkList 是不是就是指向结构体类型的指针了。

  这里的LinkList应该就是头指针了,指向整个链表,而前面的LNode应该就是节点。

  

  

posted @ 2018-12-24 16:02  lemaden  阅读(3118)  评论(2编辑  收藏  举报