我有一个用于捕获任何分段错误或ctrl- c的应用程序。使用下面的代码,我能够捕获分段错误,但是该处理程序一次又一次地被调用。我该如何阻止他们。供您参考,我不想退出我的申请。我只是可以小心释放所有损坏的缓冲区。
可能吗?
void SignalInit(void ) { struct sigaction sigIntHandler; sigIntHandler.sa_handler = mysighandler; sigemptyset(&sigIntHandler.sa_mask); sigIntHandler.sa_flags = 0; sigaction(SIGINT, &sigIntHandler, NULL); sigaction(SIGSEGV, &sigIntHandler, NULL); }
处理程序就是这样。
void mysighandler() { MyfreeBuffers(); /*related to my applciation*/ }
在这里,对于Segmentation故障信号,处理程序被多次调用,并且很明显MyfreeBuffers()给我释放已释放的内存的错误。我只想释放一次,但仍然不想退出应用程序。
请帮忙。
诸如此类的默认操作SIGSEGV是终止您的进程,但是当您为其安装了处理程序时,它将调用您的处理程序以覆盖默认行为。但是问题在于,在处理程序完成后,可能会重试段错误指令,如果您未采取措施修复第一个段错误,则重试的指令将再次出现错误,并且会继续下去。
SIGSEGV
因此,首先找出产生的指令SIGSEGV并尝试对其进行修复(您可以backtrace()在处理程序中调用类似的代码,然后自己查看出了什么问题)
backtrace()
另外,POSIX标准指出,
进程的行为通常是从信号捕获函数返回的,该信号通常不是由kill(),[RTS] sigqueue()或raise()生成的[XSI] SIGBUS,SIGFPE,SIGILL或SIGSEGV信号后返回的)。
因此,理想的做法是首先修复您的段错误。 segfault的处理程序并不旨在绕过基础错误条件
因此,最好的建议是- 不要抓住SIGSEGV。让它转储核心。分析核心。修正无效的内存引用,然后就可以了!