Scroll to navigation

std::jmp_buf(3) C++ Standard Libary std::jmp_buf(3)

NAME

std::jmp_buf - std::jmp_buf

Synopsis


Defined in header <csetjmp>
typedef /* unspecified */ jmp_buf;


The std::jmp_buf type is an array type suitable for storing information to restore a
calling environment. The stored information is sufficient to restore execution at
the correct block of the program and invocation of that block. The state of
floating-point status flags, or open files, or any other data is not stored in an
object of type std::jmp_buf.

Example

// Run this code


#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); // Go to error handler


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("Solving {}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))
{
// Error handler for solver
std::cout << "No real solution\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;
}

Output:


Solving 1x² + -3x + 2 = 0...
x₁ = 1, x₂ = 2


Solving 2x² + -3x + -2 = 0...
x₁ = -0.5, x₂ = 2


Solving 1x² + 2x + 3 = 0...
No real solution

See also


setjmp saves the context
(function macro)
longjmp jumps to specified location
(function)
C documentation for
jmp_buf

2024.06.10 http://cppreference.com