std::make_pair
Материал из cppreference.com
<tbody>
</tbody>
<tbody class="t-dcl-rev ">
</tbody><tbody>
</tbody>
| Определено в заголовочном файле <utility>
|
||
template< class T1, class T2 > std::pair<T1, T2> make_pair( T1 t, T2 u ); |
(до C++11) | |
template< class T1, class T2 > std::pair<V1, V2> make_pair( T1&& t, T2&& u ); |
(начиная с C++11) (до C++14) |
|
template< class T1, class T2 > constexpr std::pair<V1, V2> make_pair( T1&& t, T2&& u ); |
(начиная с C++14) | |
Создаёт объект std::pair, выводя целевой тип из типов аргументов.
|
Выведенные типы |
(начиная с C++11) |
Параметры
| t, u | — | значения, из которых создаётся pair |
Возвращаемое значение
Объект std::pair, содержащий заданные значения.
Пример
Запустить этот код
#include <iostream>
#include <utility>
#include <functional>
int main()
{
int n = 1;
int a[5] = {1, 2, 3, 4, 5};
// создаёт pair из двух целых
auto p1 = std::make_pair(n, a[1]);
std::cout << "Значение p1 равно "
<< "(" << p1.first << ", " << p1.second << ")\n";
// создаёт pair из ссылки на int и массива (раскладывающийся до указателя)
auto p2 = std::make_pair(std::ref(n), a);
n = 7;
std::cout << "Значение p2 равно "
<< "(" << p2.first << ", " << *(p2.second + 2) << ")\n";
}
Вывод:
Значение p1 равно (1, 2)
Значение p2 равно (7, 3)
Отчёты о дефектах
Следующие изменения поведения были применены с обратной силой к ранее опубликованным стандартам C++:
| Номер | Применён | Поведение в стандарте | Корректное поведение |
|---|---|---|---|
| LWG 181 | C++98 | типы параметров были константно-ссылочными типами, что делало невозможным передачу массивов |
изменили эти типы на типы значений |