#define setjmp(env) unspecified
概要
現在の環境を引数envに保存するマクロ。
envは、jmp_buf型のオブジェクトでなければならない。
事前条件
このマクロは以下の文脈でのみ現れる。
if文、switch文やループの条件全体- 関係演算子または等価演算子のオペランドの一つ(もう一つのオペランドは整数定数)で、その結果式が1を満たす場合
!のオペランドであり、その式が1を満たす場合- 式文の式全体(
void型へのキャストを含む)
上記以外の箇所での呼び出しは未定義の動作となる。
戻り値
直接マクロが呼び出された場合、0を返す。
それ以外(longjmp関数から)の呼び出しでは非0を返す。
なお、longjmp関数の第二引数が0の場合は、1を返す。
備考
以下の場合、動作は未定義である。
- 対応する
setjmpとlongjmpをcatchとthrowに置き換えることで、自動記憶域期間を持つオブジェクトの非トリビアルなデストラクタが呼び出される場合。例えば、setjmpとlongjmpの間で、非トリビアルなデストラクタを持つオブジェクトの生存期間が開始し、終了しない場合(ジャンプによってデストラクタを飛ばす場合) - コルーチンのサスペンションコンテキスト内で呼び出された場合
また、volatile修飾子のついていないsetjmpを呼び出した関数に対してローカルな変数で、その値がsetjmpからlongjmpの呼び出しの間で変更されたものがある場合、その変数の値は不定となる。
例
#include <iostream>
#include <csetjmp>
std::jmp_buf env;
void inner_function() {
std::cout << "何らかのエラー" << std::endl;
std::longjmp(env, 42);
}
int main () {
if (setjmp(env) == 0) {
inner_function();
} else {
std::cout << "エラーから復帰しました" << std::endl;
}
return 0;
}
出力
何らかのエラー
エラーから復帰しました
参照
MSC22-C. setjmp()、longjmp() の機能を安全に使用する