名前空間
変種
操作

std::variant<Types...>::emplace

提供: cppreference.com
< cpp‎ | utility‎ | variant
 
 
 
 
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>& emplace(std::initializer_list<U> il, Args&&... args);
(4) (C++17以上)

既存の variant オブジェクト内に、新しい値をその場で作成します。

1) emplace<I>(std::forward<Args>(args)...) と同等です。 ただし I はゼロから始まる Types... 内の T のインデックスです。 このオーバーロードは、std::is_constructible_v<T, Args...>true であり、 TTypes... 内にちょうど1回しか現れない場合にのみ、オーバーロード解決に参加します
2) emplace<I>(il, std::forward<Args>(args)...) と同等です。 ただし I はゼロから始まる Types... 内の T のインデックスです。 このオーバーロードは、std::is_constructible_v<T, std::initializer_list<U>&, Args...>true であり、 TTypes... 内にちょうど1回しか現れない場合にのみ、オーバーロード解決に参加します。
3) まず、現在格納されている値が (もしあれば) 破棄されます。 その後、引数 std::forward<Args>(args)...T_I 型の値を構築したかのように、格納されている値が直接初期化されます。 例外が投げられた場合、 *thisvalueless_by_exception になる可能性があります。 このオーバーロードは、std::is_constructible_v<T_I, Args...>true である場合にのみ、オーバーロード解決に参加します。 Isizeof...(Types) より小さくなければ、動作は未定義です。
4) まず、現在格納されている値が (もしあれば) 破棄されます。 その後、引数 il, std::forward<Args>(args)...T_I 型の値を構築したかのように、格納されている値が直接初期化されます。 例外が投げられた場合、 *thisvalueless_by_exception になる可能性があります。 このオーバーロードは、std::is_constructible_v<T_I, initializer_list<U>&, Args...>true である場合にのみ、オーバーロード解決に参加します。 Isizeof...(Types) より小さくなければ、動作は未定義です。

目次

[編集] 引数

args - 新しい値を構築するときに使用するコンストラクタ引数
il - 新しい値を構築するときに使用する initializer_list 引数

[編集] 戻り値

新たに構築された値を指す参照。

[編集] 例外

1-4) 格納される値の初期化中に投げられるあらゆる例外。

[編集]

#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 を代入します
(パブリックメンバ関数) [edit]