什么是段错误

 

什么是段错误

段错误是指程序尝试访问一段不可访问的内存。

在类Unix系统中,当出现段错误时,系统发送信号量SIGSEGV给产生段错误的进程;在Windows系统中,系统会发送异常STATUS_ACCESS_VIOLATION给产生段错误的进程。

产生段错误的原因

程序运行过程中能访问到的内存空间主要有栈和堆。栈存放了函数的本地变量,堆是程序运行过程中能够自由分配和使用的内存空间。产生段错误和栈、堆的访问密切相关。

产生段错误的原因主要有:

  • 解引用空指针
  • 访问不可访问的内存空间(如内核空间)
  • 访问不存在的内存地址
  • 试图写一个只读内存空间(如代码段)
  • 栈溢出(函数递归调用)
  • 使用未初始化的指针(定义时没有初始化或者已经回收)

避免段错误

  • 定义指针后初始化
  • 数组下标是否越界
  • 在堆上分配空间是否足够(内存限制)
  • 变量处理时格式控制是否合理

调试段错误

在Linux系统下,首先开启core dump

ulimit -c unlimited

然后执行段错误的程序:

./a.out

程序出现段错误后,会出现如下提示:

Segmentation fault (core dumped)

表明生成了core文件,存放在/proc/sys/kernel/core_pattern目录下,然后可以使用GDB进行调试。

$ gdb ./a.out core

用来查看文件出错的情况。

执行bt命令可以查看段出错的过程中调用的函数,如:

#0  0x0000000000441337 in ReorderBySort::Reorder (this=<value optimized out>, 
index_files=@0x7fff704326b0, order=ReorderBySort::ORIGIN)
at /usr/include/c++/4.3/bits/stl_vector.h:688
#1  0x00000000004424e7 in ReorderProcessor::Reorder (this=0x7fff704326b0)
at src/reorder.cpp:57
#2  0x00000000004458a9 in Reorder () at src/indexer.cc:396
#3  0x00000000004497ed in main (argc=3, argv=<value optimized out>) at src/indexer.cc:1169

调用顺序是

main -> Reorder -> ReorderProcessor::Reorder -> stl_vector.h

输入updown可以在#0, #1, #2和#3之间切换,输入list查看源代码。

要准确定位到出现段错误的位置,还需要细细查看源代码。

你可能感兴趣的:(什么是段错误)