前面讲述到了链表的操作,链表具有动态伸缩的优点,但是链表是指针操作,必然面临着指针操作的诸多问题,比如典型的空指针操作问题,出现问题之后,除了printf,还有没有其他方法调试呢?
简单举个例子:
#include <stdio.h>
#include <string.h>#define MAX_NAME_LEN 32typedef 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.outCore 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