为什么这个setjmp程序要打印一个5
Why does this setjmp program print a 5?
以下代码最终打印出"5"
#include <iostream>
#include <setjmp.h>
static jmp_buf buf;
float funcB()
{
setjmp(buf);
return 1.6f;
}
int funcA()
{
longjmp(buf,5);
std::cout<<"b";
return 2;
}
int main()
{
funcB();
std::cout<<funcA();
}
但这没有任何意义,因为setjmp返回5,而不是任何一个函数。。。别担心,我不会在任何地方使用这个代码,我只是好奇!
您试图做的事情在文档中被指定为未定义的行为:
longjmp()
函数使用相应的jmp_buf
参数恢复同一线程中最近一次调用setjmp()
所保存的环境。如果没有这样的调用,或者如果包含setjmp()
调用的函数在此期间终止了执行,则行为未定义。
由于在funcA
中调用longjmp
之前,调用setjmp
(即funcB
)的函数已经退出,因此该行为是未定义的(它在ideone上崩溃)。
不能使用longjmp返回到已退出的函数。换句话说,longjmp不会为您恢复堆栈。请参见此处。
你需要的是一个类似语言的方案,在那里做这种事情是完全正常的。
无论您使用什么编译器,都会严格解释setjmp
和longjmp
的作用:
此宏可能返回不止一次:第一次,在其直接调用;在这种情况下,它总是返回零。当longjmp为在信息设置为env的情况下调用,宏将再次返回;这如果出现以下情况,则返回传递给longjmp的值作为第二个参数与零不同,或者如果为零则为1。
从这里
因为它是UB,它可以做到这一点,点一个披萨,结束世界。。。任何东西都是有效的。
相关文章:
- 如何创建一个CMake变量,除非显式重写,否则使用默认值
- 删除一个线程上有数百万个字符串的大型哈希映射会影响另一个线程的性能
- 为什么两个不同的未命名名称空间可以共存于一个cpp文件中
- 运行同一解决方案的另一个项目的项目
- 挂起和取消挂起一个文件DLL
- 用C++中的一个变量定义一个常量
- 函数向量_指针有不同的原型,我可以构建一个吗
- 在c++中用vector填充一个简单的动态数组
- 如何在选项卡视图Qt中设置一个新项目,并保存以前的项目
- 预处理器:插入结构名称中的前一个行号
- 我在c++代码中生成了一个运行时#3异常
- 我想将一个对T类型的非常量左值引用绑定到一个T类型的临时值
- 从链接列表c++中删除一个项目
- 告诉一个 const char 数组,除了编译时 C 样式的字符串外,它不以 '