名前空間
変種
操作

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

From cppreference.com
 
 
ユーティリティライブラリ
言語サポート
型のサポート (基本型、RTTI)
ライブラリ機能検査マクロ (C++20)
プログラムユーティリティ
可変引数関数
コルーチンサポート (C++20)
契約サポート (C++26)
三方比較
(C++20)
(C++20)(C++20)(C++20)  
(C++20)(C++20)(C++20)

汎用ユーティリティ
関係演算子 (C++20で非推奨)
 
 
(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) firstother.first を、secondother.second を代入します。

このオーバーロードは、std::is_assignable<T1&, const U1&>::value および std::is_assignable<T2&, const U2&>::value の両方が true の場合にのみ、オーバーロード解決に参加します。

(C++11以降)
4) firstother.first を、secondother.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) firststd::forward<U1>(p.first) を、secondstd::forward<U2>(p.second) を代入します。
このオーバーロードは、std::is_assignable<T1&, U1>::value および std::is_assignable<T2&, U2>::value の両方が true の場合にのみ、オーバーロード解決に参加します。
8) firststd::forward<U1>(p.first) を、secondstd::forward<U2>(p.second) を代入します。
このオーバーロードは、std::is_assignable_v<const T1&, U1> および std::is_assignable_v<const T2&, U2> の両方が true の場合にのみ、オーバーロード解決に参加します。
9) firststd::get<0>(std::forward<P>(u)) を、secondstd::get<1>(std::forward<P>(u)) を代入します。
このオーバーロードは、
10) firststd::get<0>(std::forward<P>(u)) を、secondstd::get<1>(std::forward<P>(u)) を代入します。
このオーバーロードは、

目次

[編集] 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) [編集]
English 日本語 中文(简体) 中文(繁體)