setjmp
来自cppreference.com
在标头 <csetjmp> 定义
|
||
#define setjmp(env) /* 由实现定义 */ |
||
保存当前执行上下文到 std::jmp_buf 类型的变量 env。std::longjmp 函数稍后可用此变量恢复当前执行上下文。即在调用 std::longjmp 函数时,将在构造了传递给 std::longjmp 的 std::jmp_buf 变量的特定调用点处继续执行。此时 setjmp
返回传递给 std::longjmp 的值。
setjmp
的调用只能在下列语境出现:
- if、switch、while、do-while、for 语句的整个控制表达式。
switch (setjmp(env)) { // ...
- 关系或相等性运算符的操作数之一,而另一操作数是整数常量表达式,产生的表达式是 if、switch、while、do-while、for 语句的整个控制表达式。
if (setjmp(env) > 0) { // ...
- 一元 ! 运算符的操作数,产生的表达式是 if、switch、while、do-while、for 语句的整个控制表达式。
while (!setjmp(env)) { // ...
- 表达式语句(可以转型到 void)的整个表达式。
setjmp(env);
如果 setjmp
在其他语境出现,那么行为未定义。
此外,在协程中可以使用 co_await 运算符的地方调用 |
(C++20 起) |
一旦返回到 setjmp
的作用域:
- 所有可访问对象、浮点状态标志及其他抽象机组件拥有与在执行 std::longjmp 时相同的值,
- 除了含有
setjmp
调用的函数中的非 volatile 局部对象,如果在setjmp
调用后更改它们,那么它们的值不确定。
参数
env | - | 保存程序执行状态的变量 |
返回值
如果宏被原始代码调用且执行环境在 env 存储,那么返回 0。
如果刚才进行了非局部跳转,那么返回非零值。返回值与传递给 std::longjmp 的值相同。
注解
上述要求禁止在数据流中使用 setjmp
的返回值(例如用它初始化或赋值对象)。只能将返回值用于控制流或舍弃。
示例
运行此代码
#include <array> #include <cmath> #include <csetjmp> #include <cstdlib> #include <format> #include <iostream> std::jmp_buf solver_error_handler; std::array<double, 2> solve_quadratic_equation(double a, double b, double c) { const double discriminant = b * b - 4.0 * a * c; if (discriminant < 0) std::longjmp(solver_error_handler, true); // 去往错误处理器 const double delta = std::sqrt(discriminant) / (2.0 * a); const double argmin = -b / (2.0 * a); return {argmin - delta, argmin + delta}; } void show_quadratic_equation_solution(double a, double b, double c) { std::cout << std::format("求解 {}x² + {}x + {} = 0...\n", a, b, c); auto [x_0, x_1] = solve_quadratic_equation(a, b, c); std::cout << std::format("x₁ = {}, x₂ = {}\n\n", x_0, x_1); } int main() { if (setjmp(solver_error_handler)) { // 求解器的错误处理器 std::cout << "无实数解\n"; return EXIT_FAILURE; } for (auto [a, b, c] : {std::array{1, -3, 2}, {2, -3, -2}, {1, 2, 3}}) show_quadratic_equation_solution(a, b, c); return EXIT_SUCCESS; }
输出:
求解 1x² + -3x + 2 = 0... x₁ = 1, x₂ = 2 求解 2x² + -3x + -2 = 0... x₁ = -0.5, x₂ = 2 求解 1x² + 2x + 3 = 0... 无实数解
参阅
跳转到指定位置 (函数) |