Namespaces
Variants

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

From cppreference.net
Utilities library
(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 の内容のコピーで置き換える。

代入演算子は暗黙的に宣言される。この代入演算子を使用すると、 T1 または T2 がconst修飾型、参照型、コピー代入演算子がアクセス不能なクラス型、またはそのようなクラスの配列型である場合、プログラムは不適格となる。

(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) 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 の内容で置き換えます。
このオーバーロードは、以下の条件が両方とも 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 である場合にのみ、オーバーロード解決に参加します。
7) std:: forward < U1 > ( p. first ) first に、 std:: forward < U2 > ( p. second ) second に代入する。
このオーバーロードは、以下の両方が std:: is_assignable < T1 & , U1 > :: value および std:: is_assignable < T2 & , U2 > :: value の両方が true である場合にのみ、オーバーロード解決に参加します。
8) first std:: forward < U1 > ( p. first ) を代入し、 second std:: forward < U2 > ( p. second ) を代入する。
このオーバーロードは、以下の両方が std:: is_assignable_v < const T1 & , U1 > および std:: is_assignable_v < const T2 & , U2 > の両方が true である場合にのみ、オーバーロード解決に参加します。
9) first std :: get < 0 > ( std:: forward < P > ( u ) ) を代入し、 second std :: get < 1 > ( std:: forward < P > ( u ) ) を代入する。
このオーバーロードは、以下の条件がすべて満たされる場合にのみオーバーロード解決に参加します:
10) first std :: get < 0 > ( std:: forward < P > ( u ) ) を、 second std :: get < 1 > ( std:: forward < P > ( u ) ) を代入する。
このオーバーロードは、以下の条件がすべて満たされる場合にのみオーバーロード解決に参加します:

目次

パラメータ

other - このpairの内容を置き換える値のペア
p - この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++規格に対して遡及的に適用されました。

DR 適用対象 公開時の動作 正しい動作
LWG 885 C++98 異種コピー代入が欠落 追加(オーバーロード (3) として)
LWG 2729 C++11 pair::operator= が制約されておらず、
不必要な未定義動作を引き起こす可能性があった
制約を追加

関連項目

ある tuple の内容を別の tuple に代入する
( std::tuple<Types...> の公開メンバ関数)