goto statement
From Cppreference
Transfers control to the desired location
Used when it is otherwise impossible to transfer control to the desired location using conventional constructs.
Contents |
[edit] Syntax
goto label | |||||||||
[edit] Explanation
The goto statement transfers control to the location, specified by label. The goto statement must be in the same function as the label it is referring. If goto statement transfers control backwards, all objects, that are not yet initialized at the label are destructed. It is not allowed to transfer control forwards if doing so would skip initialization of an object.
[edit] Keywords
[edit] Example
#include <iostream> struct Object { ~Object() { std::cout << "d"; } }; int main() { int a = 10; //loop using goto label: Object obj; std::cout << a << " "; a = a - 2; if (a != 0) { goto label; //causes obj to be destructed } std::cout << '\n'; //get out of multi-level loop easily for (int x = 0; x < 3; x++) { for (int y = 0; y < 3; y++) { std::cout << "(" << x << ";" << y << ") " << '\n'; if (x + y >= 3) { goto endloop; } } } endloop: std::cout << '\n'; return 0; //causes obj to be destructed }
Output:
10 d8 d6 d4 d2 (0;0) (0;1) (0;2) (1;0) (1;1) (1;2) d