std::variant<Types...>::swap - cppreference.com (original) (raw)

| void swap( variant& rhs ) noexcept(/* see below */); | | (since C++17) (constexpr since C++20) | | ------------------------------------------------------ | | ------------------------------------- |

Swaps two variant objects.

The program is ill-formed unless type T_i are Swappable and std::is_move_constructible_v<T_i> is true for all T_i in Types....

Contents

[edit] Parameters

rhs - a variant object to swap with

[edit] Return value

(none)

[edit] Exceptions

If this->index() == rhs.index(), may throw any exception thrown by swap(*std::get_if<i>(this), *std::get_if<i>(std::addressof(rhs))) with i being index().

Otherwise, may throw any exception thrown by the move constructors of the alternatives currently held by *this and rhs.

[edit] Notes

Feature-test macro Value Std Feature
__cpp_lib_variant 202106L (C++20)(DR) Fully constexpr std::variant

[edit] Example

[edit] Defect reports

The following behavior-changing defect reports were applied retroactively to previously published C++ standards.

DR Applied to Behavior as published Correct behavior
P2231R1 C++20 swap was not constexpr while non-trivial destructors can be constexpr in C++20 made constexpr

[edit] See also