Пространства имён
Варианты
Действия

std::get(std::tuple)

Материал из cppreference.com
< cpp‎ | utility‎ | tuple
 
 
Библиотека утилит
Языковая поддержка
Поддержка типов (базовые типы, RTTI)
Макросы тестирования функциональности библиотеки (C++20)    
Управление динамической памятью
Программные утилиты
Поддержка сопрограмм (C++20)
Вариативные функции
Трёхстороннее сравнение (C++20)
(C++20)
(C++20)(C++20)(C++20)(C++20)(C++20)(C++20)
Общие утилиты
Дата и время
Функциональные объекты
Библиотека форматирования (C++20)
(C++11)
Операторы отношения (устарело в C++20)
Целочисленные функции сравнения
(C++20)(C++20)(C++20)    
(C++20)
Операции обмена и типа
(C++11)
(C++11)
(C++17)
Общие лексические типы
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
Элементарные преобразования строк
(C++17)
(C++17)
 
 
Определено в заголовочном файле <tuple>
template< std::size_t I, class... Types >

typename std::tuple_element<I, std::tuple<Types...>>::type&

    get( std::tuple<Types...>& t ) noexcept;
(1)(начиная с C++11)
(constexpr начиная с C++14)
template< std::size_t I, class... Types >

typename std::tuple_element<I, std::tuple<Types...>>::type&&

    get( std::tuple<Types...>&& t ) noexcept;
(2)(начиная с C++11)
(constexpr начиная с C++14)
template< std::size_t I, class... Types >

const typename std::tuple_element<I, std::tuple<Types...>>::type&

    get( const std::tuple<Types...>& t ) noexcept;
(3)(начиная с C++11)
(constexpr начиная с C++14)
template< std::size_t I, class... Types >

const typename std::tuple_element<I, std::tuple<Types...>>::type&&

    get( const std::tuple<Types...>&& t ) noexcept;
(4)(начиная с C++11)
(constexpr начиная с C++14)
template< class T, class... Types >
constexpr T& get( std::tuple<Types...>& t ) noexcept;
(5)(начиная с C++14)
template< class T, class... Types >
constexpr T&& get( std::tuple<Types...>&& t ) noexcept;
(6)(начиная с C++14)
template< class T, class... Types >
constexpr const T& get( const std::tuple<Types...>& t ) noexcept;
(7)(начиная с C++14)
template< class T, class... Types >
constexpr const T&& get( const std::tuple<Types...>&& t ) noexcept;
(8)(начиная с C++14)
1-4) Извлекает Iый элемент из tuple. I должно быть целым числом в диапазоне [0sizeof...(Types)).
5-8) Извлекает элемент tuple t типа T. Не удаётся скомпилировать, если tuple не содержит ровно один элемент этого типа.

Содержание

[править] Параметры

ttuple, содержимое которого нужно извлечь

[править] Возвращаемое значение

Ссылка на выбранный элемент t.

[править] Примечание

Макрос Тестирования функциональностиЗначениеСтандартФункциональность
__cpp_lib_tuples_by_type201304L(C++14)Адресация кортежей по типу

[править] Пример

#include <iostream>
#include <string>
#include <tuple>
 
int main()
{
    auto t = std::make_tuple(1, "Foo", 3.14);
    // Доступ на основе индекса
    std::cout << "(" << std::get<0>(t) << ", " << std::get<1>(t)
              << ", " << std::get<2>(t) << ")\n";
    // Доступ на основе типов (C++14 или новее)
    std::cout << "(" << std::get<int>(t) << ", " << std::get<const char*>(t)
              << ", " << std::get<double>(t) << ")\n";
    // Примечание: std::tie и структурные привязки также могут
    // использоваться для декомпозиции tuple.
}

Вывод:

(1, Foo, 3.14)
(1, Foo, 3.14)

[править] Отчёты о дефектах

Следующие изменения поведения были применены с обратной силой к ранее опубликованным стандартам C++:

НомерПрименёнПоведение в стандартеКорректное поведение
LWG 2485C++11 (по индексу)
C++14 (по типу)
нет перегрузок для const tuple&&перегрузки добавлены

[править] Смотрите также

Структурные привязки (C++17)привязывает указанные имена к подобъектам или элементам кортежа инициализатора[править]
предоставляет доступ к элементу array
(шаблон функции) [править]
доступ к элементу пары
(шаблон функции) [править]
читает значение variant по заданному индексу или типу (если тип уникален), генерирует исключение при ошибке
(шаблон функции) [править]
получает итератор или ограничитель из std::ranges::subrange
(шаблон функции) [править]