std:: make_pair
|
Défini dans l'en-tête
<utility>
|
||
|
template
<
class
T1,
class
T2
>
std:: pair < T1, T2 > make_pair ( T1 x, T2 y ) ; |
(jusqu'à C++11) | |
|
template
<
class
T1,
class
T2
>
std:: pair < /*V1*/ , /*V2*/ > make_pair ( T1 && x, T2 && y ) ; |
(depuis C++11)
(constexpr depuis C++14) (jusqu'à C++20) |
|
|
template
<
class
T1,
class
T2
>
constexpr
std::
pair
<
std::
unwrap_ref_decay_t
<
T1
>
,
|
(depuis C++20) | |
Crée un objet std::pair , en déduisant le type cible à partir des types des arguments.
|
Étant donnés les types
std::
decay
<
T1
>
::
type
comme
|
(depuis C++11)
(jusqu'à C++20) |
Table des matières |
Paramètres
| x, y | - | les valeurs pour construire la paire |
Valeur de retour
|
std:: pair < T1, T2 > ( x, y ) |
(jusqu'en C++11) |
|
std:: pair < /*V1*/ , /*V2*/ > ( std:: forward < T1 > ( x ) , std:: forward < T2 > ( y ) ) |
(depuis C++11)
(jusqu'en C++20) |
|
std::
pair
<
std::
unwrap_ref_decay_t
<
T1
>
,
std::
unwrap_ref_decay_t
<
T2
>>
|
(depuis C++20) |
Exemple
#include <functional> #include <iostream> #include <utility> int main() { int n = 1; int a[5] = {1, 2, 3, 4, 5}; // construire une paire à partir de deux entiers auto p1 = std::make_pair(n, a[1]); std::cout << "La valeur de p1 est " << '(' << p1.first << ", " << p1.second << ")\n"; // construire une paire à partir d'une référence à un entier et d'un tableau (décomposé en pointeur) auto p2 = std::make_pair(std::ref(n), a); n = 7; std::cout << "La valeur de p2 est " << '(' << p2.first << ", " << *(p2.second + 2) << ")\n"; }
Sortie :
La valeur de p1 est (1, 2) La valeur de p2 est (7, 3)
Rapports de défauts
Les rapports de défauts modifiant le comportement suivants ont été appliqués rétroactivement aux normes C++ précédemment publiées.
| DR | Appliqué à | Comportement publié | Comportement corrigé |
|---|---|---|---|
| LWG 181 | C++98 |
les types des paramètres étaient des types
const-référence, ce qui rendait impossible le passage de tableaux |
modifié ces
types en types valeur |