std::swap(std::variant)
From cppreference.com
| ヘッダ <variant> で定義 |
||
template< class... Types > void swap( std::variant<Types...>& lhs, |
(C++17以降) (C++20 以降 constexpr) |
|
std::swap アルゴリズムを std::variant に対してオーバーロードします。実質的に lhs.swap(rhs) を呼び出します。
このオーバーロードは、Types... 内のすべての T_i に対して std::is_move_constructible_v<T_i> および std::is_swappable_v<T_i> が両方とも true である場合にのみ、オーバーロード解決に参加します。
目次 |
[編集] Parameters
| lhs, rhs | - | 交換する値を持つ variant オブジェクト |
[編集] Return value
(なし)
[編集] Exceptions
noexcept 指定:
noexcept(noexcept(lhs.swap(rhs)))
[編集] Notes
| 機能テストマクロ | 値 | 規格 | 機能 |
|---|---|---|---|
__cpp_lib_variant |
202106L |
(C++20) (DR) |
完全な constexpr std::variant |
[編集] Example
このコードを実行
#include <iostream> #include <string> #include <variant> void print(auto const& v, char term = '\n') { std::visit([](auto&& o) { std::cout << o; }, v); std::cout << term; } int main() { std::variant<int, std::string> v1{123}, v2{"XYZ"}; print(v1, ' '); print(v2); std::swap(v1, v2); print(v1, ' '); print(v2); std::variant<double, std::string> v3{3.14}; // std::swap(v1, v3); // ERROR: ~ inconsistent parameter packs }
出力
123 XYZ XYZ 123
[編集] Defect reports
以下の動作変更を伴う欠陥報告が、以前に公開されたC++標準に遡って適用されました。
| DR | 適用対象 | 公開された動作 | 正しい動作 |
|---|---|---|---|
| P2231R1 | C++20 | C++20 では必要な操作は constexpr にできるにもかかわらず、swap は constexpr ではありませんでした。 |
constexprではありませんでした。 |
[編集] See also
別の variant と交換する(public member function) |