错误(分段故障核心转储) - 列表和结构指针

时间:2016-05-11 22:31:06

标签: c list pointers struct segmentation-fault

我是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; 
}

1 个答案:

答案 0 :(得分:1)

第一次通过插入:

q=*sPtr; 
w=q->nextPtr; 

*sPtr等于NULL。您正在取消引用这将导致q->nextPtr;上的seg-fault。