代码中有解释
为什么?因为a->next指向的是NULL,temp=NULL,这是不行的,这相当于野指针。所以我们要用temp->next。
#include <stdio.h>
#include <stdlib.h>
//我们需要先定义链表的结构体
typedef struct Link{
int elem;
struct Link * next;//这个是一个结构体型的指针
}link;
link *initLink(){
link *p= (link*)malloc(sizeof(link));
link *temp=p;
for(int i=1;i<5;i++){
link *a=(link*)malloc(sizeof(link));
a->elem=i;
a->next=NULL;
temp->next=a;
temp = temp->next;//这个地方不能是a->next;为什么?因为a->next指向的是NULL,temp=NULL,这是不行的,这相当于野指针。所以我们要用temp->next。
}
return p;
}
void display(link*p){
link *temp = p;
while (temp->next) {
temp = temp->next;//这个地方要注意,需要手动的将指针下移一个位置
printf("打印:%d\n",temp->elem);
}
printf("\n");
}
int main(){
link *p = initLink();
display(p);
return 0;
}