我是C编程的初学者;我正在尝试学习列表和指向结构的指针。这是我使用指针在元素后实现list元素的程序。有人能告诉我为什么它会给我错误分段故障核心转储?
#include<stdio.h>
#include<stdlib.h>
struct ListNode{
int x;
struct ListNode* nextPtr;
};
typedef struct ListNode ListNode;
typedef ListNode* ListNodePtr;
void insert(ListNodePtr* sPtr, int n);
int main()
{
int f;
scanf("%d", &f);
ListNodePtr startPtr=NULL;
while(f!=-1)
{
insert(&startPtr, f);
scanf("%d",&f);
printf("/n");
}
return 0;
}
void insert(ListNodePtr* sPtr, int n)
{
ListNodePtr newPtr;
newPtr=malloc(sizeof(ListNode));
if(newPtr!=NULL)
{
newPtr->x=n;
newPtr->nextPtr=NULL;
}
ListNodePtr q,w;
q=*sPtr;
w=q->nextPtr;
while(w!=NULL)
{
q=w;
w=q->nextPtr;
}
w=newPtr;
}
答案 0 :(得分:1)
第一次通过插入:
q=*sPtr;
w=q->nextPtr;
*sPtr
等于NULL。您正在取消引用这将导致q->nextPtr;
上的seg-fault。