jam*_*o00 7 c++ gcc g++ segmentation-fault
以下代码总结了我目前遇到的问题.我当前的执行流程如下,我在GCC 4.3中运行.
jmp_buf a_buf;
jmp_buf b_buf;
void b_helper()
{
printf("entering b_helper");
if(setjmp(b_buf) == 0)
{
printf("longjmping to a_buf");
longjmp(a_buf, 1);
}
printf("returning from b_helper");
return; //segfaults right here
}
void b()
{
b_helper();
}
void a()
{
printf("setjmping a_buf");
if(setjmp(a_buf) == 0)
{
printf("calling b");
b();
}
printf("longjmping to b_buf");
longjmp(b_buf, 1);
}
int main()
{
a();
}
Run Code Online (Sandbox Code Playgroud)
上述执行流程在b_helper返回后立即创建段错误.它几乎就像只有b_helper堆栈帧有效,并且它下面的堆栈被擦除.
任何人都可以解释为什么会这样吗?我猜这是一个GCC优化,它正在擦除未使用的堆栈帧或其他东西.
谢谢.
Gre*_*ill 13
您只能longjmp()备份了调用堆栈.调用longjmp(b_buf, 1)是事情开始出错的地方,因为引用b_buf后的堆栈帧不再存在longjmp(a_buf).
从以下文档longjmp:
在调用setjmp()例程的例程返回后,可能无法调用longjmp()例程.
这包括通过longjmp()函数"返回" .
标准说明了这一点longjmp()(7.13.2.1 longjmp函数):
longjmp函数使用相应的jmp_buf参数恢复最近调用setjmp宏所保存的环境.如果没有这样的调用,或者包含setjmp宏调用的函数已在临时中终止执行
用脚注澄清了这一点:
例如,通过执行return语句或因为另一个longjmp调用导致在嵌套调用集合中较早的函数中转移到setjmp调用.
所以你不能longjmp()在嵌套setjmp/ longjmp集合之间来回.
| 归档时间: |
|
| 查看次数: |
3870 次 |
| 最近记录: |