std::pair::pair
| (1) | ||
pair(); |
(до C++11) | |
constexpr pair(); |
(начиная с C++11) (conditionally explicit) |
|
| (2) | ||
pair( const T1& x, const T2& y ); |
(до C++11) | |
pair( const T1& x, const T2& y ); |
(начиная с C++11) (до C++14) (conditionally explicit) |
|
constexpr pair( const T1& x, const T2& y ); |
(начиная с C++14) (conditionally explicit) |
|
| (3) | ||
template< class U1, class U2 > pair( U1&& x, U2&& y ); |
(начиная с C++11) (до C++14) (conditionally explicit) |
|
template< class U1, class U2 > constexpr pair( U1&& x, U2&& y ); |
(начиная с C++14) (до C++23) (conditionally explicit) |
|
template< class U1 = T1, class U2 = T2 > constexpr pair( U1&& x, U2&& y ); |
(начиная с C++23) (conditionally explicit) |
|
template< class U1, class U2 > constexpr pair( pair<U1, U2>& p ); |
(4) | (начиная с C++23) (conditionally explicit) |
| (5) | ||
template< class U1, class U2 > pair( const pair<U1, U2>& p ); |
(до C++11) | |
template< class U1, class U2 > pair( const pair<U1, U2>& p ); |
(начиная с C++11) (до C++14) (conditionally explicit) |
|
template< class U1, class U2 > constexpr pair( const pair<U1, U2>& p ); |
(начиная с C++14) (conditionally explicit) |
|
| (6) | ||
template< class U1, class U2 > pair( pair<U1, U2>&& p ); |
(начиная с C++11) (до C++14) (conditionally explicit) |
|
template< class U1, class U2 > constexpr pair( pair<U1, U2>&& p ); |
(начиная с C++14) (conditionally explicit) |
|
template< class U1, class U2 > constexpr pair( const pair<U1, U2>&& p ); |
(7) | (начиная с C++23) (conditionally explicit) |
template< pair-like P > constexpr pair ( P&& u ); |
(8) | (начиная с C++23) (conditionally explicit) |
| (9) | ||
template< class... Args1, class... Args2 > pair( std::piecewise_construct_t, std::tuple<Args1...> first_args, std::tuple<Args2...> second_args ); |
(начиная с C++11) (до C++20) |
|
template< class... Args1, class... Args2 > constexpr pair( std::piecewise_construct_t, std::tuple<Args1...> first_args, std::tuple<Args2...> second_args ); |
(начиная с C++20) | |
pair( const pair& p ) = default; |
(10) | |
pair( pair&& p ) = default; |
(11) | (начиная с C++11) |
Создаёт новый pair.
first и second.
|
Этот конструктор участвует в разрешении перегрузки тогда и только тогда, когда Этот конструктор является |
(начиная с C++11) |
first значением x и second значением y.
|
Этот конструктор участвует в разрешении перегрузки тогда и только тогда, когда Этот конструктор является |
(начиная с C++11) |
first значением std::forward<U1>(x) и second значением std::forward<U2>(y). std::is_constructible_v<T1, U1> и std::is_constructible_v<T2, U2> оба равны true.explicit тогда и только тогда, когда std::is_convertible_v<U1, T1> равно false или std::is_convertible_v<U2, T2> равно false.
|
Этот конструктор определяется как удалённый, если инициализация |
(начиная с C++23) |
first значением p.first и second значением p.second.std::is_constructible_v<T1, U1&> и std::is_constructible_v<T2, U2&> оба равны true.explicit тогда и только тогда, когда std::is_convertible_v<U1&, T1> равно false или std::is_convertible_v<U2&, T2> равно false.first или second привязывает ссылку к временному объекту.first значением p.first и second значением p.second.
|
Этот конструктор участвует в разрешении перегрузки тогда и только тогда, когда Этот конструктор является |
(начиная с C++11) |
|
Этот конструктор определяется как удалённый, если инициализация |
(начиная с C++23) |
first значением std::forward<U1>(p.first) и second значением std::forward<U2>(p.second).std::is_constructible_v<T1, U1> и std::is_constructible_v<T2, U2> оба равны true.explicit тогда и только тогда, когда std::is_convertible_v<U1, T1> равно false или std::is_convertible_v<U2, T2> равно false.
|
Этот конструктор определяется как удалённый, если инициализация |
(начиная с C++23) |
first значением std::forward<const U1>(p.first) и second значением std::forward<const U2>(p.second).std::is_constructible_v<T1, U1> и std::is_constructible_v<T2, U2> оба равны true.explicit тогда и только тогда, когда std::is_convertible_v<const U1, T1> равно false или std::is_convertible_v<const U2, T2> равно false.first или second привязывает ссылку к временному объекту.u1 как std::get<0>(std::forward(u)) и u2 как std::get<1>(std::forward(u)), обозначим их типы как U1 и U2 соответственно. Инициализирует first значением u1 и second значением u2.std::remove_cvref(P)не является специализацией std::ranges::subrange,std::is_constructible_v<T1, U1>равноtrue, иstd::is_constructible_v<T2, U2равноtrue.
explicit тогда и только тогда, когда std::is_convertible_v<U1, T1> равно false или std::is_convertible_v<U2, T2> равно false.first или second привязывает ссылку к временному объекту.first_args в конструктор first и направляет элементы second_args в конструктор second. Это единственный конструктор не по умолчанию, который можно использовать для создания пары некопируемых неперемещаемых типов. Программа некорректна, если first или second является ссылкой и привязана к временному объекту.constexpr, если копирование обоих элементов соответствует требования к функциям constexpr (начиная с C++11).constexpr, если перемещение обоих элементов соответствует требованиям к функциям constexpr.Параметры
| x | — | значение для инициализации первого элемента pair |
| y | — | значение для инициализации второго элемента pair |
| p | — | pair значений, используемых для инициализации обоих элементов pair |
| u | — | объект значений pair-like, используемый для инициализации обоих элементов pair |
| first_args | — | кортеж аргументов конструктора для инициализации первого элемента pair |
| second_args | — | кортеж аргументов конструктора для инициализации второго элемента pair |
Исключения
Генерирует исключение, если хотя бы одна из указанных операций (например, конструктор элемента) генерирует исключение.
Пример
#include <complex>
#include <iostream>
#include <string>
#include <tuple>
#include <utility>
int main()
{
auto print = [](auto rem, auto const& pair)
{
std::cout << rem << "(" << pair.first << ", " << pair.second << ")\n";
};
std::pair<int, float> p1;
print("(1) Инициализированное значение: ", p1);
std::pair<int, double> p2{42, 3.1415};
print("(2) Инициализируется двумя значениями: ", p2);
std::pair<char, int> p4{p2};
print("(4) Неявно преобразуется: ", p4);
std::pair<std::complex<double>, std::string> p6
{std::piecewise_construct, std::forward_as_tuple(0.123, 7.7),
std::forward_as_tuple(10, 'a')};
print("(8) Кусочно создаётся: ", p6);
}Возможный вывод:
(1) Инициализированное значение: (0, 0)
(2) Инициализируется двумя значениями: (42, 3.1415)
(4) Неявно преобразуется: (*, 3)
(8) Кусочно создаётся: ((0.123,7.7), aaaaaaaaaa)Отчёты о дефектах
Следующие изменения поведения были применены с обратной силой к ранее опубликованным стандартам C++:
| Номер | Применён | Поведение в стандарте | Корректное поведение |
|---|---|---|---|
| LWG 265 | C++98 | конструктор по умолчанию инициализирует копированиемfirst и second значениями T1() и T2() соответственно(таким образом, требуется чтобы T1 и T2 былиCopyConstructible) |
first и second инициализируются значением
|
| LWG 2510 | C++11 | конструктор по умолчанию был неявным | сделан условно-явным |
| WG не указан | C++11 | некоторые конструкторы были неявными, что мешало некоторым использованиям |
конструкторы сделаны условно-явными |
Смотрите также
создаёт объект типа pair, определённого типами аргументов (шаблон функции) | |
создаёт новый tuple (public функция-элемент std::tuple)
|