Scroll to navigation

std::experimental::ranges::swap(3) C++ Standard Libary std::experimental::ranges::swap(3)

NAME

std::experimental::ranges::swap - std::experimental::ranges::swap

Synopsis


Defined in header <experimental/ranges/utility>
namespace {


constexpr /* unspecified */ swap = /* unspecified (ranges TS)
*/; (customization point object)


}
Call signature
template< class T, class U >


requires /* see below */


void swap( T&& t, U&& u ) noexcept(/* see below */);


Exchanges the values referenced by t and u.


A call to ranges::swap is equivalent to:


1) (void)swap(std::forward<T>(t), std::forward<U>(u)), if that expression is valid,
where the overload resolution is performed with the following candidates:
* template<class T> void swap(T&, T&) = delete;
* template<class T, std::size_t N> void swap(T(&)[N], T(&)[N]) = delete;
* any declarations of swap found by argument-dependent lookup.
If the function selected by overload resolution does not exchange the values
referenced by t and u, the program is ill-formed; no diagnostic required.
2) Otherwise, (void)ranges::swap_ranges(t, u), if T and U are lvalue references to
array types of equal extent (but possibly different element types) and
ranges::swap(*t, *u) is a valid expression.
3) Otherwise, if T and U are both V& for some type V that meets the syntactic
requirements of MoveConstructible<V> and Assignable<V&, V>, exchanges the referenced
values as if by V v{std::move(t)}; t = std::move(u); u = std::move(v);. If the
semantic requirements of either concept are not satisfied, the program is
ill-formed; no diagnostic required.
4) In all other cases, a call to ranges::swap is ill-formed.


ranges::swap can be used in a constant expression if every function it calls (as
specified above) can be so used.

Exceptions


1)
noexcept specification:
noexcept(noexcept((void)swap(std::forward<T>(t), std::forward<T>(u))))
, where swap is found as described above.
2)
noexcept specification:
noexcept(noexcept(ranges::swap(*t, *u)))
3)
noexcept specification:
noexcept(std::is_nothrow_move_constructible<V>::value &&
std::is_nothrow_move_assignable<V>::value)

Example


This section is incomplete
Reason: no example

See also


swap swaps the values of two objects
(function template)

Categories:


* conditionally noexcept
* Todo no example

2024.06.10 http://cppreference.com