c入门第十九篇: 易错的指针操作(代码的调试)

前面讲述到了链表的操作,链表具有动态伸缩的优点,但是链表是指针操作,必然面临着指针操作的诸多问题,比如典型的空指针操作问题,出现问题之后,除了printf,还有没有其他方法调试呢?

简单举个例子:

#include 
#include 

#define MAX_NAME_LEN 32

typedef struct student {
    int id; // 学号
    char name[MAX_NAME_LEN]; // 姓名
    float score; // 成绩
    struct student *next; //这里不能够使用 Student *next原因是Student还未定义。
} Student;

int main()
{
    Student *header = NULL;
    printf("%d\n", header->id);
    return 0;
}

运行代码之后,会出现coredump的错误。

#./a.out
Segmentation fault (core dumped)

我们可以通过gdb来读取,coredump信息,如下,这样我们就可以知道引起coredump的行数为第16行代码引起,然后通过打印相关信息,比如header,知道是header为空指针导致。

#gdb a.out core-a.out

Core was generated by `./a.out'.
Program terminated with signal 11, Segmentation fault.
#0  0x0000000000400541 in main () at zhizhen_null.c:16 //第16行代码引起coredump
16	    printf("%d\n", header->id);

(gdb) p header
$1 = (Student *) 0x0

这里有一点需要注意的是程序编译的时候需要加上-g,带上调试信息,方便调试。

gcc -g -Wall zhizhen_null.c

你可能感兴趣的:(c语言入门,c语言,开发语言,程序人生,调试,debug)