想问一个一直以来忽视的很基础性的问题。
严版数据结构中对于链表的定义是这样的:
typedef struct LNode{
Elemtype data;
struct LNode *next;
}LNode, *LinkList;
请问以下两个语句的区别在哪里?
LNode *p;
p = (LinkList)malloc(sizeof(LNode));
我以为这都是定义了一个结点,并将指针指向了这个借点空间,但无法区分两者的真正区别,比如定义、用法、场合
想问一个一直以来忽视的很基础性的问题。
严版数据结构中对于链表的定义是这样的:
typedef struct LNode{
Elemtype data;
struct LNode *next;
}LNode, *LinkList;
请问以下两个语句的区别在哪里?
LNode *p;
p = (LinkList)malloc(sizeof(LNode));
我以为这都是定义了一个结点,并将指针指向了这个借点空间,但无法区分两者的真正区别,比如定义、用法、场合
LNode *p;这一句只是声明了一个结构体指针变量,这个变量没有内存空间
p = (LinkList)malloc(sizeof(LNode));这一句是为指针变量分配内存空间,只有分配了内存空间,这个变量才能使用