关于SIGSEGV错误及处理方法

Posted zzfx

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于SIGSEGV错误及处理方法相关的知识,希望对你有一定的参考价值。

http://blog.csdn.net/brace/article/details/1102422

今天编程遇到了SIGSEGV错误,比较困惑,所以找了些资料,总结一下:

(1)官方说法是:
SIGSEGV --- Segment Fault. The possible cases of your encountering this error are:

1.buffer overflow --- usually caused by a pointer reference out of range.

2.stack overflow --- please keep in mind that the default stack size is 8192K.

3.illegal file access --- file operations are forbidden on our judge system.

 

 

(2)SIGBUS与SIGSEGV信号的一般区别如下:

1) SIGBUS(Bus error)意味着指针所对应的地址是有效地址,但总线不能正常使用该指针。通常是未对齐的数据访问所致。

2) SIGSEGV(Segment fault)意味着指针所对应的地址是无效地址,没有物理内存对应该地址。

 

 

(3)Linux的mmap(2)手册页

--------------------------------------------------------------------------
使用映射可能涉及到如下信号

SIGSEGV

    试图对只读映射区域进行写操作

SIGBUS

    试图访问一块无文件内容对应的内存区域,比如超过文件尾的内存区域,或者以前有文件内容对应,现在为另一进程截断过的内存区域。
--------------------------------------------------------------------------

 

 

弄清楚错误以后,就要查找产生错误的根源,一般我用以下两种方法:

(1)gcc -g 编译 
     ulimit -c 20000 
     之后运行程序,等core dump 
     最后gdb -c core <exec file> 

     来查调用栈

(2)使用strace execfile,运行程序,出错时会显示那个系统调用错

以上是关于关于SIGSEGV错误及处理方法的主要内容,如果未能解决你的问题,请参考以下文章

什么导致 SIGSEGV

如何使用 SIGSEGV 的信号处理程序调试程序

如何在tid xxxxx(Thread-X)中解决Android致命信号11(SIGSEGV),代码1,故障地址0x0?

我在以下代码(指针)上收到 SIGSEGV 错误,不知道哪里出错了

错误 A/libc:SkPath 中 0x00000018(代码=1)处的致命信号 11(SIGSEGV)

Fatal signal xx (SIGSEGV) at