在linxu中经常发生段错误(segment fault)的原因

        我们在linux上写代码,并运行程序时,经常会碰到程序执行到一半发生“segment fault”的错误,一头雾水,而且对这类问题的排查也是相当麻烦的一件事。而且我在面试的过程中也被面试官问到过这个问题,所以了解发生这个问题的原因对于在linux开发的技术人员来说是很有必要的。


        引起这个错误的典型情况是对非法指针解引用。当指针指向一个不允许读或写的内存地址,而程序却试图利用指针来读或写该地址的时候,就会出现在该错误。

        在Linux或Windows的内存布局中,有些地址是始终不能读写的,例如0地址。还有地址是一开始不允许读写,应用程序必须实现请求获取这些地址的读写权,或者某些地址一开始并没有映射到实际的物理内存,应用程序必须实现请求将这些地址映射到实际的物理地址,之后才能够自由地读写这片内存。当一个指针指向这些区域的时候,对它指向的内存进行读写就会引发错误。

        造成这种错误最普遍的原因有两种:

        (1)程序员将指针初始化为NULL,之后却没有给它一个合理的值就开始使用指针;

        (2)程序员没有初始化栈上的指针,指针的值一般会使随机数,之后就直接开始使用指针。

        因此,如果你的程序出现了这样的错误,请着重检查指针的使用情况。


猜你喜欢

转载自blog.csdn.net/kang___xi/article/details/80454948