栗子1:
void Example()
{
LinkList L = NULL;
LinkList S;
int x;
printf("请输入链表元素 或以-1结束输入")
while(x!=-1)
{
S=(LinkList)malloc(sizeof(LNode));
S->data=x;
S->next=H;
L = S;
scanf(%d,&x);
}
}
此代码中:在定义结构体指针变量S时用到了malloc函数,而定义结构体指针变量L时则没有用到malloc函数。
原因:L没有指向有效地内存地址,而S指向了有效的内存地址。正是因为S指向了有效地内存地址,所以可以往S指向的内存地址里面写值:S->data=x;而在后来L指向的地址就是每一个新的S指向的地址:L=S。
栗子2:
LinkList L;
L->data=x;
这是错的。因为L没有指向确切的地址,所以不能通过L来向它要指向的地址赋值。
栗子3:
LinkList L;
LNode Node;
L=&Node;
L->data=x;
这是对的。因为L指向Node的地址,L->data=x 等同于 Node.data=x。
总结
malloc的作用就类似以上代码的作用。但是不用再定义一个结构体变量Node,让结构体指针变量L指向它的地址&Node,只用直接使用malloc函数就可以让结构体指针变量L指向一个确切的内存地址。