Namensräume
Varianten
Aktionen

std::make_pair

Von cppreference.com
< cpp‎ | utility‎ | pair
 
 
Dienstprogramm-Bibliotheken
Sprachunterstützung
Typunterstützung (Basistypen, RTTI)
Bibliotheks-Feature-Test-Makros (C++20)
Programm-Dienstprogramme
Variadische Funktionen
Coroutine-Unterstützung (C++20)
Vertragsunterstützung (C++26)
Drei-Wege-Vergleich
(C++20)
(C++20)(C++20)(C++20)  
(C++20)(C++20)(C++20)

Allgemeine Hilfsmittel
Relationale Operatoren (in C++20 veraltet)
 
 
Definiert in der Header-Datei <utility>
template< class T1, class T2 >
std::pair<T1, T2> make_pair( T1 x, T2 y );
(bis C++11)
template< class T1, class T2 >
std::pair</*V1*/, /*V2*/> make_pair( T1&& x, T2&& y );
(seit C++11)
(constexpr seit C++14)
(bis C++20)
template< class T1, class T2 >

constexpr std::pair<std::unwrap_ref_decay_t<T1>,
                    std::unwrap_ref_decay_t<T2>>

    make_pair( T1&& x, T2&& y );
(seit C++20)

Erstellt ein std::pair-Objekt, wobei der Zieltyp aus den Typen der Argumente abgeleitet wird.

Gegeben die Typen std::decay<T1>::type als U1 und std::decay<T2>::type als U2, sind die Typen /*V1*/ und /*V2*/ wie folgt definiert:

(seit C++11)
(bis C++20)

Inhalt

[edit] Parameter

x, y - die Werte, aus denen das Paar erstellt wird

[edit] Rückgabewert

std::pair<T1, T2>(x, y)

(bis C++11)

std::pair</*V1*/, /*V2*/>(std::forward<T1>(x), std::forward<T2>(y))

(seit C++11)
(bis C++20)

std::pair<std::unwrap_ref_decay_t<T1>, std::unwrap_ref_decay_t<T2>>
    (std::forward<T1>(x), std::forward<T2>(y))

(seit C++20)

[edit] Beispiel

#include <functional>
#include <iostream>
#include <utility>
 
int main()
{
    int n = 1;
    int a[5] = {1, 2, 3, 4, 5};
 
    // build a pair from two ints
    auto p1 = std::make_pair(n, a[1]);
    std::cout << "The value of p1 is "
              << '(' << p1.first << ", " << p1.second << ")\n";
 
    // build a pair from a reference to int and an array (decayed to pointer)
    auto p2 = std::make_pair(std::ref(n), a);
    n = 7;
    std::cout << "The value of p2 is "
              << '(' << p2.first << ", " << *(p2.second + 2) << ")\n";
}

Ausgabe

The value of p1 is (1, 2)
The value of p2 is (7, 3)

[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 181 C++98 die Parametertypen waren const-Referenzen
Typen, was die Übergabe von Arrays unmöglich machte
diese geändert
Typen auf Werttypen