std::pair<T1,T2>::operator=
來自 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 起) |
替換 pair 的內容。
1) 複製賦值運算子。用 `other` 內容的副本替換內容。
賦值運算子是隱式宣告的。如果 |
(C++11 前) |
如果 std::is_copy_assignable<T1>::value 或 std::is_copy_assignable<T2>::value 為 false,則此過載被定義為刪除。 |
(C++11 起) |
2) const-qualified 運算元的複製賦值運算子。
3) 將 other.first 賦值給
first
,將 other.second 賦值給 second
。
僅當 std::is_assignable<T1&, const U1&>::value 和 std::is_assignable<T2&, const U2&>::value 都為 true 時,此過載才參與過載決議。 |
(C++11 起) |
4) 將 other.first 賦值給
first
,將 other.second 賦值給 second
。 僅當 std::is_assignable_v<const T1&, const U1&> 和 std::is_assignable_v<const T2&, const U2&> 都為 true 時,此過載才參與過載決議。
5) 移動賦值運算子。使用移動語義替換內容為 other 的內容。
6) const-qualified 運算元的移動賦值運算子。
僅當以下條件成立時,此過載才參與過載決議:
- 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。
目錄 |
[編輯] 引數
其他 | - | 要替換此 pair 內容的 pair 值 |
p | - | 要替換此 pair 內容的 pair 值,可能型別不同 |
u | - | pair-like 要替換此 pair 內容的值物件 |
型別要求 | ||
-T1 必須滿足 U1 的 CopyAssignable 要求。(直至 C++11) | ||
-T2 必須滿足 U2 的 CopyAssignable 要求。(直至 C++11) |
[編輯] 返回值
*this
[編輯] 異常
1-4) 可能丟擲實現定義的異常。
5)
noexcept 規範:
noexcept(
std::is_nothrow_move_assignable<T1>::value &&
std::is_nothrow_move_assignable<T2>::value
6-10) 可能丟擲實現定義的異常。
[編輯] 示例
執行此程式碼
#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, {}}
[編輯] 缺陷報告
下列更改行為的缺陷報告追溯地應用於以前出版的 C++ 標準。
缺陷報告 | 應用於 | 釋出時的行為 | 正確的行為 |
---|---|---|---|
LWG 885 | C++98 | 缺少異構複製賦值 | 已新增(作為過載 (3)) |
LWG 2729 | C++11 | pair::operator= 未受約束,可能導致不必要的未定義行為 |
已受約束 |
[編輯] 參閱
將一個 tuple 的內容賦值給另一個( std::tuple<Types...> 的公共成員函式) |