Scroll to navigation

std::swap(std::pair)(3) C++ Standard Libary std::swap(std::pair)(3)

NAME

std::swap(std::pair) - std::swap(std::pair)

Synopsis


Defined in header <utility>
template< class T1, class T2 >
(since C++11)
void swap( std::pair<T1,T2>& x, std::pair<T1,T2>& y ) (until C++20)


noexcept(/* see below */);
template< class T1, class T2 >


constexpr void swap( std::pair<T1,T2>& x, std::pair<T1,T2>& y (since C++20)
) (1)


noexcept(/* see below */);
template< class T1, class T2 >


constexpr void swap( const std::pair<T1,T2>& x, const (2) (since C++23)
std::pair<T1,T2>& y )


noexcept(/* see below */);


Swaps the contents of x and y. Equivalent to x.swap(y).


1) This overload participates in overload resolution only if
std::is_swappable_v<first_type> && std::is_swappable_v<second_type> is
true. (since C++17)
2) This overload participates in overload resolution only if
std::is_swappable_v<const first_type> && std::is_swappable_v<const
second_type> is true.

Parameters


x, y - pairs whose contents to swap

Return value


(none)

Exceptions


noexcept specification:
noexcept(noexcept(x.swap(y)))

Example

// Run this code


#include <iostream>
#include <utility>


int main()
{
auto p1 = std::make_pair(10, 3.14);
auto p2 = std::pair(12, 1.23); // CTAD, since C++17


auto print_p1_p2 = [&](auto msg) {
std::cout << msg
<< "p1 = {" << std::get<0>(p1)
<< ", " << std::get<1>(p1) << "}, "
<< "p2 = {" << std::get<0>(p2)
<< ", " << std::get<1>(p2) << "}\n";
};


print_p1_p2("Before p1.swap(p2): ");
p1.swap(p2);
print_p1_p2("After p1.swap(p2): ");
std::swap(p1, p2);
print_p1_p2("After swap(p1, p2): ");
}

Output:


Before p1.swap(p2): p1 = {10, 3.14}, p2 = {12, 1.23}
After p1.swap(p2): p1 = {12, 1.23}, p2 = {10, 3.14}
After swap(p1, p2): p1 = {10, 3.14}, p2 = {12, 1.23}

See also


swap swaps the values of two objects
(function template)
std::swap(std::tuple) specializes the std::swap algorithm
(C++11) (function template)

Category:


* conditionally noexcept

2024.06.10 http://cppreference.com