std::pair<T1,T2>:: swap
| (1) | ||
|
void
swap
(
pair
&
other
)
noexcept
(
/* ver más abajo */
)
;
|
(desde C++11)
(hasta C++20) |
|
|
constexpr
void
swap
(
pair
&
other
)
noexcept
(
/* ver más abajo */
)
;
|
(desde C++20) | |
|
constexpr
void
swap
(
const
pair
&
other
)
const
noexcept
(
/* ver más abajo */
)
;
|
(2) | (desde C++23) |
Intercambia
first
con
other.first
y
second
con
other.second
, como si fuera mediante
using
std::
swap
;
swap
(
first, other.
first
)
;
swap
(
second, other.
second
)
;
.
|
Si alguna de las llamadas a la función
|
(hasta C++23) |
|
1)
El programa está mal formado si
std::
is_swappable_v
<
T1
>
o
std::
is_swappable_v
<
T2
>
no es
true
.
2)
El programa está mal formado si
std::
is_swappable_v
<
const
T1
>
o
std::
is_swappable_v
<
const
T2
>
no es
true
.
Si alguna de las llamadas a la función
|
(desde C++23) |
Contenidos |
Parámetros
| otro | - | par de valores a intercambiar |
Valor de retorno
(ninguno)
Excepciones
|
noexcept
especificación:
noexcept
(
noexcept
(
swap
(
first, other.
first
)
)
&&
En la expresión anterior, el identificador
|
(hasta C++17) |
|
1)
noexcept
especificación:
noexcept
(
std::
is_nothrow_swappable_v
<
first_type
>
&&
2)
noexcept
especificación:
noexcept
(
std::
is_nothrow_swappable_v
<
const
first_type
>
&&
|
(desde C++17) |
Ejemplo
#include <iostream> #include <utility> #include <string> int main() { std::pair<int, std::string> p1(10, "test"), p2; p2.swap(p1); std::cout << "(" << p2.first << ", " << p2.second << ")\n"; #if __cpp_lib_ranges_zip >= 202110L // Usando la sobrecarga calificada const de swap de C++23 // (swap ya no propaga la constancia del pair) int i1 = 10, i2{}; std::string s1("test"), s2; const std::pair<int&, std::string&> r1(i1, s1), r2(i2, s2); r2.swap(r1); std::cout << "(" << i2 << ", " << s2 << ")\n"; #endif }
Salida posible:
(10, test) (10, test)
Informes de defectos
Los siguientes informes de defectos que modifican el comportamiento se aplicaron retroactivamente a los estándares de C++ publicados anteriormente.
| DR | Aplicado a | Comportamiento publicado | Comportamiento correcto |
|---|---|---|---|
| LWG 2456 | C++11 |
la especificación
noexcept
está mal formada
|
se hizo funcionar |
Véase también
|
intercambia los valores de dos objetos
(plantilla de función) |
|
intercambia el contenido de dos
tuple
s
(función miembro pública de
std::tuple<Types...>
)
|