std::multimap<Key,T,Compare,Allocator>:: operator=
|
multimap
&
operator
=
(
const
multimap
&
other
)
;
|
(1) | (constexpr since C++26) |
| (2) | ||
|
multimap
&
operator
=
(
multimap
&&
other
)
;
|
(since C++11)
(until C++17) |
|
|
multimap
&
operator
=
(
multimap
&&
other
)
noexcept ( /* see below */ ) ; |
(since C++17)
(constexpr since C++26) |
|
|
multimap
&
operator
=
(
std::
initializer_list
<
value_type
>
ilist
)
;
|
(3) |
(since C++11)
(constexpr since C++26) |
コンテナの内容を置き換えます。
traits
を
std::
allocator_traits
<
allocator_type
>
とします:
|
traits :: propagate_on_container_copy_assignment :: value が true の場合、 * this のアロケータは other のコピーで置き換えられる。代入後の * this のアロケータが古い値と等しくないと比較される場合、古いアロケータを使用してメモリを解放した後、新しいアロケータを使用して要素をコピーする前にメモリを確保する。それ以外の場合、 * this が所有するメモリは可能な場合に再利用される。いずれの場合も、元々 * this に属していた要素は、破棄されるか、要素ごとのコピー代入で置き換えられる可能性がある。 |
(C++11以降) |
目次 |
パラメータ
| other | - | データソースとして使用する別のコンテナ |
| ilist | - | データソースとして使用する初期化子リスト |
戻り値
* this
計算量
例外
|
2)
noexcept
仕様:
noexcept
(
std::
allocator_traits
<
Allocator
>
::
is_always_equal
::
value
&& std:: is_nothrow_move_assignable < Compare > :: value ) |
(C++17以降) |
注記
コンテナのムーブ代入(オーバーロード ( 2 ) 後)、要素ごとのムーブ代入が互換性のないアロケータによって強制されない限り、 other への参照、ポインタ、およびイテレータ(終端イテレータを除く)は有効なままですが、現在は * this 内の要素を参照します。現在の標準は [container.reqmts]/67 の包括的な記述によってこの保証を行っており、より直接的な保証が LWG issue 2321 を通じて検討中です。
例
以下のコードは operator = を使用して、一方の std::multimap をもう一方に代入します:
#include <initializer_list> #include <iostream> #include <iterator> #include <map> #include <utility> void print(const auto comment, const auto& container) { auto size = std::size(container); std::cout << comment << "{ "; for (const auto& [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); }
出力:
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} }
関連項目
multimap
を構築する
(public member function) |