std::pair<T1,T2>::operator=
| (1) | ||
pair& operator=( const pair& other ); |
(bis C++20) | |
| constexpr pair& operator=( const pair& other ); |
(seit C++20) | |
| constexpr const pair& operator=( const pair& other ) const; |
(2) | (seit C++23) |
| (3) | ||
template< class U1, class U2 > pair& operator=( const pair<U1, U2>& other ); |
(bis C++20) | |
| template< class U1, class U2 > constexpr pair& operator=( const pair<U1, U2>& other ); |
(seit C++20) | |
| template< class U1, class U2 > constexpr const pair& operator=( const pair<U1, U2>& other ) const; |
(4) | (seit C++23) |
| (5) | ||
pair& operator=( pair&& other ) noexcept(/* siehe unten */); |
(seit C++11) (bis C++20) |
|
| constexpr pair& operator=( pair&& other ) noexcept(/* siehe unten */); |
(seit C++20) | |
| constexpr const pair& operator=( pair&& other ) const; |
(6) | (seit C++23) |
| (7) | ||
template< class U1, class U2 > pair& operator=( pair<U1, U2>&& p ); |
(seit C++11) (bis C++20) |
|
| template< class U1, class U2 > constexpr pair& operator=( pair<U1, U2>&& p ); |
(seit C++20) | |
| template< class U1, class U2 > constexpr const pair& operator=( pair<U1, U2>&& p ) const; |
(8) | (seit C++23) |
| template< pair-like P > constexpr pair& operator=( P&& u ); |
(9) | (seit C++23) |
| template< pair-like P > constexpr const pair& operator=( P&& u ) const; |
(10) | (seit C++23) |
Ersetzt den Inhalt des Paares.
|
Der Zuweisungsoperator ist implizit deklariert. Die Verwendung dieses Zuweisungsoperators macht das Programm schlecht geformt, wenn entweder |
(bis C++11) |
|
Diese Überladung ist als gelöscht definiert, wenn entweder std::is_copy_assignable<T1>::value oder std::is_copy_assignable<T2>::value false ist. |
(seit C++11) |
first und other.second second zu.|
Diese Überladung nimmt nur an der Überladungsauflösung teil, wenn std::is_assignable<T1&, const U1&>::value und std::is_assignable<T2&, const U2&>::value beide true sind. |
(seit C++11) |
first und other.second second zu.- std::same_as<std::remove_cvref_t<P>, std::pair> false ist,
- std::remove_cvref_t<P> keine Spezialisierung von std::ranges::subrange ist,
- std::is_assignable_v<T1&, decltype(std::get<0>(std::forward<P>(p)))> true ist, und
- std::is_assignable_v<T2&, decltype(std::get<1>(std::forward<P>(p)))> true ist.
- std::same_as<std::remove_cvref_t<P>, std::pair> false ist,
- std::remove_cvref_t<P> keine Spezialisierung von std::ranges::subrange ist,
- std::is_assignable_v<const T1&, decltype(std::get<0>(std::forward<P>(p)))> ist true, und
- std::is_assignable_v<const T2&, decltype(std::get<1>(std::forward<P>(p)))> ist true.
Inhalt |
[edit] Parameter
| Sonstiges | - | Paar von Werten, um den Inhalt dieses Paares zu ersetzen |
| p | - | Paar von Werten möglicherweise unterschiedlicher Typen, um den Inhalt dieses Paares zu ersetzen |
| u | - | paar-ähnliches Objekt von Werten, um den Inhalt dieses Paares zu ersetzen |
| Typanforderungen | ||
-T1 muss die Anforderungen von CopyAssignable von U1 erfüllen. (bis C++11) | ||
-T2 muss die Anforderungen von CopyAssignable von U2 erfüllen. (bis C++11) | ||
[edit] Rückgabewert
*this
[edit] Ausnahmen
std::is_nothrow_move_assignable<T1>::value &&
std::is_nothrow_move_assignable<T2>::value
[edit] Beispiel
#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'; }
Ausgabe
(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, {}}
[edit] Fehlerberichte
Die folgenden Verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.
| DR | angewendet auf | Verhalten wie veröffentlicht | Korrigiertes Verhalten |
|---|---|---|---|
| LWG 885 | C++98 | Fehlende heterogene Kopierzuweisung | hinzugefügt (als Überladung (3)) |
| LWG 2729 | C++11 | pair::operator= war unbeschränkt und könntezu unnötigem undefiniertem Verhalten führen |
eingeschränkt |
[edit] Siehe auch
weist den Inhalt eines tuple einem anderen zu(öffentliche Memberfunktion von std::tuple<Types...>) |