std::get_if (std::variant)
From cppreference.com
| ヘッダ <variant> で定義 |
||
| (1) | (C++17以降) | |
| template< std::size_t I, class... Types > constexpr std::add_pointer_t<std::variant_alternative_t<I, std::variant<Types...>>> |
||
| template< std::size_t I, class... Types > constexpr std::add_pointer_t<const std::variant_alternative_t<I, std::variant<Types...>>> |
||
| (2) | (C++17以降) | |
| template< class T, class... Types > constexpr std::add_pointer_t<T> |
||
| template< class T, class... Types > constexpr std::add_pointer_t<const T> |
||
1) インデックスベースの例外を投げないアクセサー: pv がヌルポインタではなく、かつ pv->index() == I の場合、pv が指す variant に格納されている値へのポインタを返します。それ以外の場合は、ヌルポインタ値を返します。
I が variant の有効なインデックスでない場合、呼び出しは ill-formed です。2) 型ベースの例外を投げないアクセサー: Types... における
T のゼロベースのインデックスを I として (1) と同等です。T が Types... の一意な要素でない場合、呼び出しは ill-formed です。目次 |
[編集] テンプレートパラメータ
| I | - | 検索するインデックス |
| 型 | - | 検索する一意な型 |
[編集] パラメータ
| pv | - | variantへのポインタ |
[編集] 戻り値
指し示された variant に格納されている値へのポインタ。エラー時にはヌルポインタ。
[編集] 例
このコードを実行
#include <iostream> #include <variant> int main() { auto check_value = [](const std::variant<int, float>& v) { if (const int* pval = std::get_if<int>(&v)) std::cout << "variant value: " << *pval << '\n'; else std::cout << "failed to get value!" << '\n'; }; std::variant<int, float> v{12}, w{3.f}; check_value(v); check_value(w); }
出力
variant value: 12 failed to get value!
[編集] 関連項目
| (C++17) |
インデックスまたは型(型が一意である場合)を指定して variant の値を読み取る。エラーの場合は例外をスローする (function template) |