(1) | ||
pair& operator=( const pair& other ); | (until C++20) | |
constexpr pair& operator=( const pair& other ); | (since C++20) | |
constexpr const pair& operator=( const pair& other ) const; | (2) | (since C++23) |
(3) | ||
template< class U1, class U2 > pair& operator=( const pair<U1, U2>& other ); | (since C++11) (until C++20) | |
template< class U1, class U2 > constexpr pair& operator=( const pair<U1, U2>& other ); | (since C++20) | |
template< class U1, class U2 > constexpr const pair& operator=( const pair<U1, U2>& other ) const; | (4) | (since C++23) |
(5) | ||
pair& operator=( pair&& other ) noexcept(/* see below */); | (since C++11) (until C++20) | |
constexpr pair& operator=( pair&& other ) noexcept(/* see below */); | (since C++20) | |
constexpr const pair& operator=( pair&& other ) const; | (6) | (since C++23) |
(7) | ||
template< class U1, class U2 > pair& operator=( pair<U1, U2>&& p ); | (since C++11) (until C++20) | |
template< class U1, class U2 > constexpr pair& operator=( pair<U1, U2>&& p ); | (since C++20) | |
template< class U1, class U2 > constexpr const pair& operator=( pair<U1, U2>&& p ) const; | (8) | (since C++23) |
template< pair-like P > constexpr pair& operator=( P&& u ); | (9) | (since C++23) |
template< pair-like P > constexpr const pair& operator=( P&& u ) const; | (10) | (since C++23) |
Replaces the contents of the pair.
other
. The assignment operator is implicitly declared. Using this assignment operator makes the program ill-formed if either | (until C++11) |
This overload is defined as deleted if either | (since C++11) |
std::is_copy_assignable_v<const T1>
and std::is_copy_assignable_v<const T2>
are both true
.other.first
to first
and other.second
to second
.std::is_assignable<T1&, const U1&>::value
and std::is_assignable<T2&, const U2&>::value
are both true
.other.first
to first
and other.second
to second
.std::is_assignable_v<const T1&, const U1&>
and std::is_assignable_v<const T2&, const U2&>
are both true
.other
using move semantics.std::is_move_assignable<T1>::value
and std::is_move_assignable<T2>::value
are both true
.std::is_assignable_v<const T1&, T1>
and std::is_assignable_v<const T2&, T2>
are both true
.std::is_assignable<T1&, U1>::value
and std::is_assignable<T2&, U2>::value
are both true
.std::is_assignable_v<const T1&, U1>
and std::is_assignable_v<const T2&, U2>
are both true
.std::same_as<std::remove_cvref_t<P>, std::pair>
is false
, std::ranges::subrange
, std::is_assignable_v<T1&, decltype(std::get<0>(std::forward<P>(p)))>
is true
, and std::is_assignable_v<T1&, decltype(std::get<1>(std::forward<P>(p)))>
is true
.std::same_as<std::remove_cvref_t<P>, std::pair>
is false
, std::ranges::subrange
, std::is_assignable_v<const T1&, decltype(std::get<0>(std::forward<P>(p)))>
is true
, and std::is_assignable_v<const T1&, decltype(std::get<1>(std::forward<P>(p)))>
is true
.other | - | pair of values to replace the contents of this pair |
p | - | pair of values of possibly different types to replace the contents of this pair |
u | - | pair-like object of values to replace the contents of this pair |
*this
.
noexcept
specification: noexcept(
std::is_nothrow_move_assignable<T1>::value &&
std::is_nothrow_move_assignable<T2>::value
.
)
#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'; }
Output:
(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, {}}
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
DR | Applied to | Behavior as published | Correct behavior |
---|---|---|---|
LWG 2729 | C++11 | pair::operator= was unconstrained and mightresult in unnecessary undefined behavior | constrained |
(C++11) | assigns the contents of one tuple to another (public member function of std::tuple<Types...> ) |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/cpp/utility/pair/operator%3D