std::vector<T,Allocator>::swap
De cppreference.com
<tbody>
</tbody>
<tbody class="t-dcl-rev ">
</tbody><tbody>
</tbody>
void swap( vector& other ); |
(hasta C++17) | |
void swap( vector& other ) noexcept(/* véase más abajo */); |
(desde C++17) (hasta C++20) |
|
constexpr void swap( vector& other ) noexcept(/* véase más abajo */); |
(desde C++20) | |
Intercambia el contenido del contenedor con el de other. No invoca ninguna operación de movimiento, copia o intercambio en los elementos individuales.
Todos los iteradores y referencias se mantienen válidos. Se invalida el iterador después del final.
|
Si |
(desde C++11) |
Parámetros
| other | - | El contenedor con el cual intercambiar el contenido. |
Valor de retorno
(Ninguno)
Excepciones
|
(Ninguna) |
(hasta C++17) | ||||||
|
Especificación noexcept: (desde C++11)
<tbody>
</tbody>
|
(desde C++17) |
Complejidad
Constante.
Ejemplo
Ejecuta este código
#include <iostream>
#include <vector>
template<class Os, class Co> Os& operator<<(Os& os, const Co& co) {
os << "{";
for (auto const& i : co) { os << ' ' << i; }
return os << " } ";
}
int main()
{
std::vector<int> a1{1, 2, 3}, a2{4, 5};
auto it1 = std::next(a1.begin());
auto it2 = std::next(a2.begin());
int& ref1 = a1.front();
int& ref2 = a2.front();
std::cout << a1 << a2 << *it1 << ' ' << *it2 << ' ' << ref1 << ' ' << ref2 << '\n';
a1.swap(a2);
std::cout << a1 << a2 << *it1 << ' ' << *it2 << ' ' << ref1 << ' ' << ref2 << '\n';
// Ten en cuenta que después del intercambio los iteradores y las referencias
// se quedan asociadas con sus elementos originales. Por ejemplo, it1 apuntaba
// a un elemento 'a1' con valor 2; aún apunta a este mismo elemento, aunque
// este elemento se movió a 'a2'.
}
Salida:
{ 1 2 3 } { 4 5 } 2 5 1 4
{ 4 5 } { 1 2 3 } 2 5 1 4
Véase también
| Especializa el algoritmo std::swap. (plantilla de función) |