我一直试图在我的代码(使用setjmp)中跟踪一个间歇性的崩溃错误,并将其缩小为:在使用/O2编译时显示,使用/O2 /Oy-,即只显示省略的帧指针。
http://msdn.microsoft.com/en-us/library/2kxx5t2c(v=vs.80).aspx建议setjmp需要一个框架指针。因此:
编辑:,我已经把它缩小了一点。
在调用setjmp的函数上启用框架指针没有什么区别,但这是因为编译器已经在这样做了,就像它应该做的那样,显然注意到需要这样做,并自动执行它。
真正起作用的是启用主帧指针。这并不像听起来那么奇怪,因为崩盘是从main的回报中显现出来的。现在我想起来了,我可以在google快速搜索setjmp用法中找到所有的例子,主要是这样做的。也许微软编译器团队只是以这种方式对其进行测试。
这是使用它的惯用方式,也许最好的解决方法是将setjmp使用函数内联到main中。
发布于 2011-05-12 16:59:10
好的,我已经发布了一个带有独立测试用例的bug报告,希望有一个修复程序:http://connect.microsoft.com/VisualStudio/feedback/details/666704/visual-c-generates-incorrect-code-with-omit-frame-pointer-and-setjmp。
同时,解决方法是不使用省略框架指针,或者将调用setjmp的代码放在main中,或者将调用longjmp的函数放在与调用setjmp相同的源文件中。
发布于 2011-05-12 17:37:09
您能指定更多关于坠机本身的信息吗?我的意思是,为longjmp生成的编译器是在longjmp之后,还是在尝试访问自动变量时,还是在尝试退出函数时立即发生崩溃?
我猜目标函数必须用标准的堆栈框架编译,对使用longjmp的函数似乎没有合理的限制。
https://stackoverflow.com/questions/5887552
复制相似问题