名稱空間
變體
操作

std::pair<T1,T2>::operator=

來自 cppreference.com
< cpp‎ | utility‎ | pair
 
 
 
 
(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` 內容的副本替換內容。

賦值運算子是隱式宣告的。如果 T1T2 是 const-qualified 型別、引用型別、具有不可訪問的複製賦值運算子的類型別,或者是此類型別的陣列型別,則使用此賦值運算子將使程式格式錯誤。

(C++11 前)

如果 std::is_copy_assignable<T1>::valuestd::is_copy_assignable<T2>::valuefalse,則此過載被定義為刪除。

(C++11 起)
2) const-qualified 運算元的複製賦值運算子。
僅當 std::is_copy_assignable_v<const T1>std::is_copy_assignable_v<const T2> 都為 true 時,此過載才參與過載決議。
3)other.first 賦值給 first,將 other.second 賦值給 second

僅當 std::is_assignable<T1&, const U1&>::valuestd::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 的內容。
僅當 std::is_move_assignable<T1>::valuestd::is_move_assignable<T2>::value 都為 true 時,此過載才參與過載決議。
6) const-qualified 運算元的移動賦值運算子。
僅當 std::is_assignable_v<const T1&, T1>std::is_assignable_v<const T2&, T2> 都為 true 時,此過載才參與過載決議。
7)std::forward<U1>(p.first) 賦值給 first,將 std::forward<U2>(p.second) 賦值給 second
僅當 std::is_assignable<T1&, U1>::valuestd::is_assignable<T2&, U2>::value 都為 true 時,此過載才參與過載決議。
8)std::forward<U1>(p.first) 賦值給 first,將 std::forward<U2>(p.second) 賦值給 second
僅當 std::is_assignable_v<const T1&, U1>std::is_assignable_v<const T2&, U2> 都為 true 時,此過載才參與過載決議。
9)std::get<0>(std::forward<P>(u)) 賦值給 first,將 std::get<1>(std::forward<P>(u)) 賦值給 second
僅當以下條件成立時,此過載才參與過載決議:
10)std::get<0>(std::forward<P>(u)) 賦值給 first,將 std::get<1>(std::forward<P>(u)) 賦值給 second
僅當以下條件成立時,此過載才參與過載決議:

目錄

[編輯] 引數

其他 - 要替換此 pair 內容的 pair 值
p - 要替換此 pair 內容的 pair 值,可能型別不同
u - pair-like 要替換此 pair 內容的值物件
型別要求
-
T1 必須滿足 U1CopyAssignable 要求。(直至 C++11)
-
T2 必須滿足 U2CopyAssignable 要求。(直至 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...> 的公共成員函式) [編輯]