table of contents
        
      
      
    - Tumbleweed 2024.07.05-1.3
 - Leap-16.0
 - Leap-15.6
 
| std::pair::operator=(3) | C++ Standard Libary | std::pair::operator=(3) | 
NAME¶
std::pair::operator= - std::pair::operator=
Synopsis¶
 pair& operator=( const pair& other ); (until
  
   C++20)
  
   constexpr pair& operator=( const pair& other (since
  
   ); C++20)
  
   constexpr const pair& operator=( const pair& (2) (since
  
   other ) const; C++23)
  
   template< class U1, class U2 > (until
  
   pair& operator=( const pair<U1, U2>& other C++20)
  
   );
  
   template< class U1, class U2 > (since
  
   constexpr pair& operator=( const pair<U1, C++20)
  
   U2>& other );
  
   template< class U1, class U2 > (since
  
   constexpr const pair& operator=( const (4) C++23)
  
   pair<U1, U2>& other ) const;
  
   (since
  
   pair& operator=( pair&& other ) noexcept(/* C++11)
  
   see below */); (until
  
   (1) C++20)
  
   constexpr pair& operator=( pair&& other ) (since
  
   noexcept(/* see below */); C++20)
  
   constexpr const pair& operator=( pair&& (3) (6)
    (since
  
   other ) const; C++23)
  
   (since
  
   template< class U1, class U2 > C++11)
  
   pair& operator=( pair<U1, U2>&& p ); (until
  
   (5) C++20)
  
   template< class U1, class U2 > (since
  
   constexpr pair& operator=( pair<U1, U2>&& p C++20)
  
   );
  
   template< class U1, class U2 > (7) (since
  
   constexpr const pair& operator=( pair<U1, (8) C++23)
  
   U2>&& p ) const;
  
   template< pair-like P > (9) (since
  
   constexpr pair& operator=( P&& u ); C++23)
  
   template< pair-like P > (since
  
   constexpr const pair& operator=( P&& u ) (10) C++23)
  
   const;
  
   Replaces the contents of the pair.
  
   1) Copy assignment operator. Replaces the contents with a copy of the
    contents of
  
   other.
  
   The assignment operator is implicitly declared. Using this assignment
  
   operator makes the program ill-formed if either T1 or T2 is a (until
    C++11)
  
   const-qualified type, or a reference type, or a class type with an
  
   inaccessible copy assignment operator, or an array type of such class.
  
   This overload is defined as deleted if either
  
   std::is_copy_assignable<T1>::value or (since C++11)
  
   std::is_copy_assignable<T2>::value is false.
  
   2) Copy assignment operator for const-qualified operand.
  
   This overload participates in overload resolution only if
  
   std::is_copy_assignable_v<const T1> and
    std::is_copy_assignable_v<const T2> are both
  
   true.
  
   3) Assigns other.first to first and other.second to second.
  
   This overload participates in overload resolution only if
  
   std::is_assignable<T1&, const U1&>::value and
    std::is_assignable<T2&, (since C++11)
  
   const U2&>::value are both true.
  
   4) Assigns other.first to first and other.second to second.
  
   This overload participates in overload resolution only if
    std::is_assignable_v<const
  
   T1&, const U1&> and std::is_assignable_v<const T2&, const
    U2&> are both true.
  
   5) Move assignment operator. Replaces the contents with those of other using
    move
  
   semantics.
  
   This overload participates in overload resolution only if
  
   std::is_move_assignable<T1>::value and
    std::is_move_assignable<T2>::value are both
  
   true.
  
   6) Move assignment operator for const-qualified operand.
  
   This overload participates in overload resolution only if
    std::is_assignable_v<const
  
   T1&, T1> and std::is_assignable_v<const T2&, T2> are both
    true.
  
   7) Assigns std::forward<U1>(p.first) to first and
    std::forward<U2>(p.second) to
  
   second.
  
   This overload participates in overload resolution only if
    std::is_assignable<T1&,
  
   U1>::value and std::is_assignable<T2&, U2>::value are both true.
  
   8) Assigns std::forward<U1>(p.first) to first and
    std::forward<U2>(p.second) to
  
   second.
  
   This overload participates in overload resolution only if
    std::is_assignable_v<const
  
   T1&, U1> and std::is_assignable_v<const T2&, U2> are both
    true.
  
   9) Assigns std::get<0>(std::forward<P>(u)) to first and
  
   std::get<1>(std::forward<P>(u)) to second.
  
   This overload participates in overload resolution only if
  
   * std::same_as<std::remove_cvref_t<P>, std::pair> is false,
  
   * std::remove_cvref_t<P> is not a specialization of
    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.
  
   10) Assigns std::get<0>(std::forward<P>(u)) to first and
  
   std::get<1>(std::forward<P>(u)) to second.
  
   This overload participates in overload resolution only if
  
   * std::same_as<std::remove_cvref_t<P>, std::pair> is false,
  
   * std::remove_cvref_t<P> is not a specialization of
    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.
Parameters¶
 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
Type requirements¶
 -
  
   T1 must meet the requirements of CopyAssignable from U1. (until C++11)
  
   -
  
   T2 must meet the requirements of CopyAssignable from U2. (until
  C++11)
Return value¶
*this
Exceptions¶
 1-4) May throw implementation-defined exceptions.
  
   5)
  
   noexcept specification:
  
   noexcept(
  
   std::is_nothrow_move_assignable<T1>::value &&
  
   std::is_nothrow_move_assignable<T2>::value
  
   )
  
   6-10) May throw implementation-defined exceptions.
Example¶
// Run this code
  
   #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';
  
   }
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, {}}
  
   Defect reports
  
   The following behavior-changing defect reports were applied retroactively to
  
   previously published C++ standards.
  
   DR Applied to Behavior as published Correct behavior
  
   LWG 885 C++98 missing heterogeneous copy assignment added (as overload
    (3))
  
   pair::operator= was unconstrained and
  
   LWG 2729 C++11 might constrained
  
   result in unnecessary undefined behavior
See also¶
 operator= assigns the contents of one tuple to another
  
   (public member function of std::tuple<Types...>)
Category:¶
* conditionally noexcept
| 2024.06.10 | http://cppreference.com |