std::pair<T1,T2>::operator=
From cppreference.com
| (1) | ||
pair& operator=( const pair& other ); |
(C++20まで) | |
| constexpr pair& operator=( const pair& other ); |
(C++20以降) | |
| constexpr const pair& operator=( const pair& other ) const; |
(2) | (C++23から) |
| (3) | ||
template< class U1, class U2 > pair& operator=( const pair<U1, U2>& other ); |
(C++20まで) | |
| template< class U1, class U2 > constexpr pair& operator=( const pair<U1, U2>& other ); |
(C++20以降) | |
| template< class U1, class U2 > constexpr const pair& operator=( const pair<U1, U2>& other ) const; |
(4) | (C++23から) |
| (5) | ||
pair& operator=( pair&& other ) noexcept(/* see below */); |
(C++11以降) (C++20まで) |
|
| constexpr pair& operator=( pair&& other ) noexcept(/* see below */); |
(C++20以降) | |
| constexpr const pair& operator=( pair&& other ) const; |
(6) | (C++23から) |
| (7) | ||
template< class U1, class U2 > pair& operator=( pair<U1, U2>&& p ); |
(C++11以降) (C++20まで) |
|
| template< class U1, class U2 > constexpr pair& operator=( pair<U1, U2>&& p ); |
(C++20以降) | |
| template< class U1, class U2 > constexpr const pair& operator=( pair<U1, U2>&& p ) const; |
(8) | (C++23から) |
| template< pair-like P > constexpr pair& operator=( P&& u ); |
(9) | (C++23から) |
| template< pair-like P > constexpr const pair& operator=( P&& u ) const; |
(10) | (C++23から) |
ペアの内容を置き換えます。
1) コピー代入演算子。コンテナの内容を other の内容のコピーで置き換えます。
|
代入演算子は暗黙的に宣言されます。この代入演算子を使用すると、 |
(C++11まで) |
|
このオーバーロードは、std::is_copy_assignable<T1>::value または std::is_copy_assignable<T2>::value のいずれかが false の場合、定義済みですが削除されます。 |
(C++11以降) |
2) const 修飾されたオペランドのコピー代入演算子。
このオーバーロードは、std::is_copy_assignable_v<const T1> および std::is_copy_assignable_v<const T2> の両方が true の場合にのみ、オーバーロード解決に参加します。
3)
first に other.first を、second に other.second を代入します。|
このオーバーロードは、std::is_assignable<T1&, const U1&>::value および std::is_assignable<T2&, const U2&>::value の両方が true の場合にのみ、オーバーロード解決に参加します。 |
(C++11以降) |
4)
first に other.first を、second に other.second を代入します。 このオーバーロードは、std::is_assignable_v<const T1&, const U1&> および std::is_assignable_v<const T2&, const U2&> の両方が true の場合にのみ、オーバーロード解決に参加します。
5) 移動代入演算子。ムーブセマンティクスを使用して、
other の内容で内容を置き換えます。 このオーバーロードは、std::is_move_assignable<T1>::value および std::is_move_assignable<T2>::value の両方が true の場合にのみ、オーバーロード解決に参加します。
6) const 修飾されたオペランドの移動代入演算子。
このオーバーロードは、std::is_assignable_v<const T1&, T1> および std::is_assignable_v<const T2&, T2> の両方が true の場合にのみ、オーバーロード解決に参加します。
このオーバーロードは、std::is_assignable<T1&, U1>::value および std::is_assignable<T2&, U2>::value の両方が true の場合にのみ、オーバーロード解決に参加します。
このオーバーロードは、std::is_assignable_v<const T1&, U1> および std::is_assignable_v<const T2&, U2> の両方が true の場合にのみ、オーバーロード解決に参加します。
このオーバーロードは、
- std::same_as<std::remove_cvref_t<P>, std::pair> は false、
- std::remove_cvref_t<P> は std::ranges::subrange の特殊化ではなく、
- std::is_assignable_v<T1&, decltype(std::get<0>(std::forward<P>(p)))> は true、そして
- std::is_assignable_v<T1&, decltype(std::get<1>(std::forward<P>(p)))> は true。
このオーバーロードは、
- std::same_as<std::remove_cvref_t<P>, std::pair> は false、
- std::remove_cvref_t<P> は std::ranges::subrange の特殊化ではなく、
- std::is_assignable_v<const T1&, decltype(std::get<0>(std::forward<P>(p)))> は true、そして
- std::is_assignable_v<const T1&, decltype(std::get<1>(std::forward<P>(p)))> は true。
目次 |
[編集] Parameters
| その他 | - | このペアの内容を置き換える値のペア |
| p | - | このペアの内容を置き換える、型が異なる可能性のある値のペア |
| u | - | このペアの内容を置き換える値の pair-like オブジェクト |
| 型要件 | ||
-T1 は (C++11まで) U1 からの CopyAssignable の要件を満たす必要があります。 | ||
-T2 は (C++11まで) U2 からの CopyAssignable の要件を満たす必要があります。 | ||
[編集] Return value
*this
[編集] Exceptions
1-4) 実装定義の例外を送出する可能性があります。
5)
noexcept 指定:
noexcept(
std::is_nothrow_move_assignable<T1>::value &&
std::is_nothrow_move_assignable<T2>::value
6-10) 実装定義の例外を送出する可能性があります。
[編集] Example
このコードを実行
#include <cstddef> #include <iomanip> #include <iostream> #include <utility> #include <vector> template<class Os, class T> Os& operator<<(Os& os, const std::vector<T>& v) { os << '{'; for (std::size_t t = 0; t != v.size(); ++t) os << v[t] << (t + 1 < v.size() ? ", " : ""); return os << '}'; } template<class Os, class U1, class U2> Os& operator<<(Os& os, const std::pair<U1, U2>& pair) { return os << '{' << pair.first << ", " << pair.second << '}'; } int main() { std::pair<int, std::vector<int>> p{1, {2}}, q{2, {5, 6}}; p = q; // (1) operator=(const pair& other); std::cout << std::setw(23) << std::left << "(1) p = q;" << "p: " << p << " q: " << q << '\n'; std::pair<short, std::vector<int>> r{4, {7, 8, 9}}; p = r; // (3) operator=(const pair<U1, U2>& other); std::cout << std::setw(23) << "(3) p = r;" << "p: " << p << " r: " << r << '\n'; p = std::pair<int, std::vector<int>>{3, {4}}; p = std::move(q); // (5) operator=(pair&& other); std::cout << std::setw(23) << "(5) p = std::move(q);" << "p: " << p << " q: " << q << '\n'; p = std::pair<int, std::vector<int>>{5, {6}}; p = std::move(r); // (7) operator=(pair<U1, U2>&& other); std::cout << std::setw(23) << "(7) p = std::move(r);" << "p: " << p << " r: " << r << '\n'; }
出力
(1) p = q; p: {2, {5, 6}} q: {2, {5, 6}}
(3) p = r; p: {4, {7, 8, 9}} r: {4, {7, 8, 9}}
(5) p = std::move(q); p: {2, {5, 6}} q: {2, {}}
(7) p = std::move(r); p: {4, {7, 8, 9}} r: {4, {}}
[編集] Defect reports
以下の動作変更を伴う欠陥報告が、以前に公開されたC++標準に遡って適用されました。
| DR | 適用対象 | 公開された動作 | 正しい動作 |
|---|---|---|---|
| LWG 885 | C++98 | 異種コピー代入の欠如 | 追加されました(オーバーロード (3) として) |
| LWG 2729 | C++11 | pair::operator= に制約がなく、不要な未定義動作を招く可能性があった |
制約付き |
[編集] See also
ある tuple の内容を別の tuple に代入する( std::tuple<Types...> の public member function) |