LINUX:段错误

什么是段错误

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

在类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命令可以查看段出错的过程中调用的函数,如:

 
  1. #0 0x0000000000441337 in ReorderBySort::Reorder (this=<value optimized out>,

  2. index_files=@0x7fff704326b0, order=ReorderBySort::ORIGIN)

  3. at /usr/include/c++/4.3/bits/stl_vector.h:688

  4. #1 0x00000000004424e7 in ReorderProcessor::Reorder (this=0x7fff704326b0)

  5. at src/reorder.cpp:57

  6. #2 0x00000000004458a9 in Reorder () at src/indexer.cc:396

  7. #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查看源代码。

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

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值