std:: swap (std::pair)
|
Definiert in Header
<utility>
|
||
| (1) | ||
|
template
<
class
T1,
class
T2
>
void
swap
(
std::
pair
<
T1,T2
>
&
x,
std::
pair
<
T1,T2
>
&
y
)
|
(seit C++11)
(bis C++20) |
|
|
template
<
class
T1,
class
T2
>
constexpr
void
swap
(
std::
pair
<
T1,T2
>
&
x,
std::
pair
<
T1,T2
>
&
y
)
|
(seit C++20) | |
|
template
<
class
T1,
class
T2
>
constexpr
void
swap
(
const
std::
pair
<
T1,T2
>
&
x,
const
std::
pair
<
T1,T2
>
&
y
)
|
(2) | (seit C++23) |
Tauscht den Inhalt von
x
und
y
. Entspricht
x.
swap
(
y
)
.
|
1)
Diese Überladung nimmt nur dann an der Überladungsauflösung teil, wenn
std::
is_swappable_v
<
first_type
>
&&
std::
is_swappable_v
<
second_type
>
true
ist.
2)
Diese Überladung nimmt nur dann an der Überladungsauflösung teil, wenn
std::
is_swappable_v
<
const
first_type
>
&&
std::
is_swappable_v
<
const
second_type
>
true
ist.
|
(seit C++17) |
Inhaltsverzeichnis |
Parameter
| x, y | - | Paare, deren Inhalte ausgetauscht werden sollen |
Rückgabewert
(keine)
Ausnahmen
Beispiel
#include <iostream> #include <utility> int main() { auto p1 = std::make_pair(10, 3.14); auto p2 = std::pair(12, 1.23); // CTAD, seit 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("Vor p1.swap(p2): "); p1.swap(p2); print_p1_p2("Nach p1.swap(p2): "); std::swap(p1, p2); print_p1_p2("Nach swap(p1, p2): "); }
Ausgabe:
Vor p1.swap(p2): p1 = {10, 3.14}, p2 = {12, 1.23}
Nach p1.swap(p2): p1 = {12, 1.23}, p2 = {10, 3.14}
Nach swap(p1, p2): p1 = {10, 3.14}, p2 = {12, 1.23}
Siehe auch
|
tauscht die Werte zweier Objekte
(Funktions-Template) |
|
|
(C++11)
|
spezialisiert den
std::swap
Algorithmus
(Funktions-Template) |