std::get(std::pair)
Материал из cppreference.com
<tbody>
</tbody>
| Определено в заголовочном файле <utility>
|
||
template< std::size_t I, class T1, class T2 > typename std::tuple_element<I, std::pair<T1,T2> >::type& get( std::pair<T1, T2>& p ) noexcept; |
(1) | (начиная с C++11) (constexpr since C++14) |
template< std::size_t I, class T1, class T2 > const typename std::tuple_element<I, std::pair<T1,T2> >::type& get( const std::pair<T1,T2>& p ) noexcept; |
(2) | (начиная с C++11) (constexpr since C++14) |
template< std::size_t I, class T1, class T2 > typename std::tuple_element<I, std::pair<T1,T2> >::type&& get( std::pair<T1,T2>&& p ) noexcept; |
(3) | (начиная с C++11) (constexpr since C++14) |
template< std::size_t I, class T1, class T2 > const typename std::tuple_element<I, std::pair<T1,T2> >::type&& get( const std::pair<T1,T2>&& p ) noexcept; |
(4) | (начиная с C++11) (constexpr since C++14) |
template <class T, class U> constexpr T& get(std::pair<T, U>& p) noexcept; |
(5) | (начиная с C++14) |
template <class T, class U> constexpr const T& get(const std::pair<T, U>& p) noexcept; |
(6) | (начиная с C++14) |
template <class T, class U> constexpr T&& get(std::pair<T, U>&& p) noexcept; |
(7) | (начиная с C++14) |
template <class T, class U> constexpr const T&& get(const std::pair<T, U>&& p) noexcept; |
(8) | (начиная с C++14) |
template <class T, class U> constexpr T& get(std::pair<U, T>& p) noexcept; |
(9) | (начиная с C++14) |
template <class T, class U> constexpr const T& get(const std::pair<U, T>& p) noexcept; |
(10) | (начиная с C++14) |
template <class T, class U> constexpr T&& get(std::pair<U, T>&& p) noexcept; |
(11) | (начиная с C++14) |
template <class T, class U> constexpr const T&& get(const std::pair<U, T>&& p) noexcept; |
(12) | (начиная с C++14) |
Извлекает элемент из пары, используя интерфейс tuple-like.
1-4) Перегрузки на основе индекса не компилируются, если индекс
I не является ни 0, ни 1.5-12) Перегрузки на основе типов не скомпилируются, если типы
T и U совпадают.Параметры
| p | — | pair, содержимое которого нужно извлечь |
Возвращаемое значение
1-4) Возвращает ссылку на
p.first, если I == 0, и ссылку на p.second, если I == 1.5-8) Возвращает ссылку на
p.first.9-12) Возвращает ссылку на
p.second.Пример
Запустить этот код
#include <iostream>
#include <utility>
int main()
{
auto p = std::make_pair(1, 3.14);
std::cout << '(' << std::get<0>(p) << ", " << std::get<1>(p) << ")\n";
std::cout << '(' << std::get<int>(p) << ", " << std::get<double>(p) << ")\n";
}
Вывод:
(1, 3.14)
(1, 3.14)
Отчёты о дефектах
Следующие изменения поведения были применены с обратной силой к ранее опубликованным стандартам C++:
| Номер | Применён | Поведение в стандарте | Корректное поведение |
|---|---|---|---|
| LWG 2485 | C++11 (по индексу) C++14 (по типу) |
нет перегрузок для const pair&& | перегрузки добавлены |
Смотрите также
| Структурные привязки (C++17) | привязывает указанные имена к подобъектам или элементам кортежа инициализатора |
(C++11) |
доступ к определённому элементу кортежа (шаблон функции) |
(C++11) |
предоставляет доступ к элементу array (шаблон функции) |
(C++17) |
читает значение variant по заданному индексу или типу (если тип уникален), генерирует исключение при ошибке (шаблон функции) |
(C++20) |
получает итератор или ограничитель из std::ranges::subrange (шаблон функции) |