setjmp

来自cppreference.com
< cpp‎ | utility‎ | program
 
 
工具库
通用工具
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中弃用)
整数比较函数
(C++20)(C++20)(C++20)
(C++20)
swap 与类型运算
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
常用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
初等字符串转换
(C++17)
(C++17)
 
程序支持工具
程序终止
(C++11)
(C++11)
不可达控制流
与环境交流
信号
信号类型
非局部跳转
setjmp
类型
 
在标头 <csetjmp> 定义
#define setjmp(env) /* implementation-defined */

保存当前执行环境到 std::jmp_buf 类型变量 envstd::longjmp 函数稍后可用此变量恢复当前执行环境。即在调用 std::longjmp 函数时,执行在构造了传递给 std::longjmpstd::jmp_buf 特定调用点继续。该情况下 setjmp 返回传递给 std::longjmp 的值。

setjmp 的调用必须只出现在下列语境之一:

switch(setjmp(env)) { ..
  • 比较或等于运算符的操作数之一,而另一操作数是整数常量表达式,产生的表达式是 ifswitchwhiledo-whilefor 语句的整个控制表达式。
if(setjmp(env) > 0) { ...
  • 一元 ! 运算符的操作数,产生的表达式是 ifswitchwhiledo-whilefor 语句的整个控制表达式。
while(!setjmp(env)) { ...
setjmp(env);

setjmp 出现于任何其他语境,则行为未定义。

一旦返回到 setjmp 的作用域,所有可访问对象、浮点状态标志及其他抽象机组件拥有与在执行 std::longjmp 时相同的值,除了含有 setjmp 调用的函数中的非 volatile 局部对象,在 setjmp 调用后更改它们,则其值不确定。

参数

env - 保存程序执行状态的变量。

返回值

若宏被原始代码调用且执行环境存储于 env 则返回 0

若刚进行了非局部跳转则返回非零值。返回值同传递给 std::longjmp 的值。

注解

上述要求禁止在数据流中使用 setjmp 的返回值(例如以之初始化或赋值对象)。只能将返回值用于控制流或舍弃。

示例

#include <iostream>
#include <csetjmp>
 
std::jmp_buf jump_buffer;
 
[[noreturn]] void a(int count) 
{
    std::cout << "a(" << count << ") called\n";
    std::longjmp(jump_buffer, count+1);  // setjump() 将返回 count+1
}
 
int main()
{
    volatile int count = 0; // 在 setjmp 作用域中被修改的局部变量必须是 volatile
    if (setjmp(jump_buffer) != 9) { // 在一个 if 内不等于常量表达式
        a(++count);  // 这会导致 setjmp() 退出
    }
}

输出:

a(1) called
a(2) called
a(3) called
a(4) called
a(5) called
a(6) called
a(7) called
a(8) called

参阅

跳转到指定位置
(函数)