std::variant<Types...>::emplace
提供: cppreference.com
template <class T, class... Args> T& emplace(Args&&... args); |
(1) | (C++17以上) |
template <class T, class U, class... Args> T& emplace( std::initializer_list<U> il, Args&&... args ); |
(2) | (C++17以上) |
template <size_t I, class... Args> std::variant_alternative_t<I, variant>& emplace( Args&&... args ); |
(3) | (C++17以上) |
template <size_t I, class U, class... Args> std::variant_alternative_t<I, variant>& |
(4) | (C++17以上) |
既存の variant
オブジェクト内に、新しい値をその場で作成します。
1) emplace<I>(std::forward<Args>(args)...) と同等です。 ただし
I
はゼロから始まる Types...
内の T
のインデックスです。 このオーバーロードは、std::is_constructible_v<T, Args...>
が true
であり、 T
が Types...
内にちょうど1回しか現れない場合にの��、オーバーロード解決に参加します2) emplace<I>(il, std::forward<Args>(args)...) と同等です。 ただし
I
はゼロから始まる Types...
内の T
のインデックスです。 このオーバーロードは、std::is_constructible_v<T, std::initializer_list<U>&, Args...>
が true
であり、 T
が Types...
内にちょうど1回しか現れない場合にのみ、オーバーロード解決に参加します。3) まず、現在格納されている値が (もしあれば) 破棄されます。 その後、引数 std::forward<Args>(args)... で
T_I
型の値を構築したかのように、格納されている値が直接初期化されます。 例外が投げられた場合、 *this
は valueless_by_exception になる可能性があります。 このオーバーロードは、std::is_constructible_v<T_I, Args...>
が true
である場合にのみ、オーバーロード解決に参加します。 I
が sizeof...(Types) より小さくなければ、動作は未定義です。4) まず、現在格納されている値が (もしあれば) 破棄されます。 その後、引数 il, std::forward<Args>(args)... で
T_I
型の値を構築したかのように、格納されている値が直接初期化されます。 例外が投げられた場合、 *this
は valueless_by_exception になる可能性があります。 このオーバーロードは、std::is_constructible_v<T_I, initializer_list<U>&, Args...>
が true
である場合にのみ、オーバーロード解決に参加します。 I
が sizeof...(Types) より小さくなければ、動作は未定義です。目次 |
[編集] 引数
args | - | 新しい値を構築するときに使用するコンストラクタ引数 |
il | - | 新しい値を構築するときに使用する initializer_list 引数 |
[編集] 戻り値
新たに構築された値を指す参照。
[編集] 例外
1-4) 格納される値の初期化中に投げられるあらゆる例外。
[編集] 例
Run this code
#include <iostream> #include <string> #include <variant> int main() { std::variant<std::string> v1; v1.emplace<0>("abc"); // OK std::cout << std::get<0>(v1) << '\n'; v1.emplace<std::string>("def"); // OK std::cout << std::get<0>(v1) << '\n'; std::variant<std::string, std::string> v2; v2.emplace<1>("ghi"); // OK std::cout << std::get<1>(v2) << '\n'; // v2.emplace<std::string>("abc"); -> Error }
出力:
abc def ghi
[編集] 関連項目
variant を代入します (パブリックメンバ関数) |