std::multimap<Key,T,Compare,Allocator>::operator=
multimap& operator=( const multimap& other ); |
(1) | |
(2) | ||
multimap& operator=( multimap&& other ); |
(since C++11) (until C++17) |
|
multimap& operator=( multimap&& other ) noexcept(/* see below */); |
(since C++17) | |
multimap& operator=( std::initializer_list<value_type> ilist ); |
(3) | (since C++11) |
Replaces the contents of the container.
other
.
If std::allocator_traits<allocator_type>::propagate_on_container_copy_assignment::value is true, the allocator of *this is replaced by a copy of that of |
(since C++11) |
other
using move semantics (i.e. the data in other
is moved from other
into this container). other
is in a valid but unspecified state afterwards.other
. If it is false and the allocators of *this and other
do not compare equal, *this cannot take ownership of the memory owned by other
and must move-assign each element individually, allocating additional memory using its own allocator as needed. In any case, all elements originally belong to *this are either destroyed or replaced by element-wise move-assignment.ilist
.Parameters
other | - | another container to use as data source |
ilist | - | initializer list to use as data source |
Return value
*this
Complexity
other
.other
.Exceptions
May throw implementation-defined exceptions. |
(until C++17) |
1,3) May throw implementation-defined exceptions.
2) noexcept specification:
noexcept(std::allocator_traits<Allocator>::is_always_equal::value && std::is_nothrow_move_assignable<Compare>::value) |
(since C++17) |
Notes
After container move assignment (overload (2)), unless element-wise move assignment is forced by incompatible allocators, references, pointers, and iterators (other than the end iterator) to other
remain valid, but refer to elements that are now in *this. The current standard makes this guarantee via the blanket statement in [container.requirements.general]/12, and a more direct guarantee is under consideration via LWG 2321.
Example
The following code uses operator= to assign one std::multimap to another:
#include <map> #include <iterator> #include <iostream> #include <utility> #include <initializer_list> void print(auto const comment, auto const& container) { auto size = std::size(container); std::cout << comment << "{ "; for (auto const& [key, value]: container) std::cout << '{' << key << ',' << value << (--size ? "}, " : "} "); std::cout << "}\n"; } int main() { std::multimap<int, int> x { {1,1}, {2,2}, {3,3} }, y, z; const auto w = { std::pair<const int, int>{4,4}, {5,5}, {6,6}, {7,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); }
Output:
Initially: x = { {1,1}, {2,2}, {3,3} } y = { } z = { } Copy assignment copies data from x to y: x = { {1,1}, {2,2}, {3,3} } y = { {1,1}, {2,2}, {3,3} } Move assignment moves data from x to z, modifying both x and z: x = { } z = { {1,1}, {2,2}, {3,3} } Assignment of initializer_list w to z: w = { {4,4}, {5,5}, {6,6}, {7,7} } z = { {4,4}, {5,5}, {6,6}, {7,7} }
See also
constructs the multimap (public member function) |