std::forward_list<T,Allocator>:: operator=
|
forward_list
&
operator
=
(
const
forward_list
&
other
)
;
|
(1) |
(desde C++11)
(constexpr desde C++26) |
| (2) | ||
|
forward_list
&
operator
=
(
forward_list
&&
other
)
;
|
(desde C++11)
(hasta C++17) |
|
|
forward_list
&
operator
=
(
forward_list
&&
other
)
noexcept ( /* ver más abajo */ ) ; |
(desde C++17)
(constexpr desde C++26) |
|
|
forward_list
&
operator
=
(
std::
initializer_list
<
value_type
>
ilist
)
;
|
(3) |
(desde C++11)
(constexpr desde C++26) |
Reemplaza el contenido del contenedor.
Sea
traits
como
std::
allocator_traits
<
allocator_type
>
:
Contenidos |
Parámetros
| other | - | otro contenedor para usar como fuente de datos |
| ilist | - | lista de inicializadores para usar como fuente de datos |
Valor de retorno
* this
Complejidad
Excepciones
|
2)
noexcept
especificación:
noexcept
(
std::
allocator_traits
<
Allocator
>
::
is_always_equal
::
value
)
|
(desde C++17) |
Notas
Después de la asignación de movimiento del contenedor (sobrecarga ( 2 ) ), a menos que la asignación de movimiento elemento por elemento sea forzada por asignadores incompatibles, las referencias, punteros e iteradores (excepto el iterador final) a other permanecen válidos, pero refieren a elementos que ahora están en * this . El estándar actual garantiza esto mediante la declaración general en [container.reqmts]/67 , y se está considerando una garantía más directa a través de LWG issue 2321 .
Ejemplo
El siguiente código utiliza operator = para asignar un std::forward_list a otro:
#include <initializer_list> #include <iostream> #include <iterator> #include <forward_list> void print(const auto comment, const auto& container) { auto size = std::ranges::distance(container); std::cout << comment << "{ "; for (const auto& element : container) std::cout << element << (--size ? ", " : " "); std::cout << "}\n"; } int main() { std::forward_list<int> x{1, 2, 3}, y, z; const auto w = {4, 5, 6, 7}; std::cout << "Initially:\n"; print("x = ", x); print("y = ", y); print("z = ", z); std::cout << "Copy assignment copies data from x to y:\n"; y = x; print("x = ", x); print("y = ", y); std::cout << "Move assignment moves data from x to z, modifying both x and z:\n"; z = std::move(x); print("x = ", x); print("z = ", z); std::cout << "Assignment of initializer_list w to z:\n"; z = w; print("w = ", w); print("z = ", z); }
Salida:
Initially:
x = { 1, 2, 3 }
y = { }
z = { }
Copy assignment copies data from x to y:
x = { 1, 2, 3 }
y = { 1, 2, 3 }
Move assignment moves data from x to z, modifying both x and z:
x = { }
z = { 1, 2, 3 }
Assignment of initializer_list w to z:
w = { 4, 5, 6, 7 }
z = { 4, 5, 6, 7 }
Véase también
construye el
forward_list
(función miembro pública) |
|
|
asigna valores al contenedor
(función miembro pública) |