std::get(std::tuple)
Материал из cppreference.com
<tbody>
</tbody>
| Определено в заголовочном файле <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 должно быть целым числом в диапазоне [0, sizeof...(Types)).5-8) Извлекает элемент tuple
t типа T. Не удаётся скомпилировать, если tuple не содержит ровно один элемент этого типа.Параметры
| t | — | tuple, содержимое которого нужно извлечь |
Возвращаемое значение
Ссылка на выбранный элемент t.
Примечание
| Макрос Тестирования функциональности | Значение | Стандарт | Функциональность |
|---|---|---|---|
__cpp_lib_tuples_by_type |
201304L |
(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 2485 | C++11 (по индексу) C++14 (по типу) |
нет перегрузок для const tuple&& | перегрузки добавлены |
Смотрите также
| Структурные привязки (C++17) | привязывает указанные имена к подобъектам или элементам кортежа инициализатора |
(C++11) |
предоставляет доступ к элементу array (шаблон функции) |
(C++11) |
доступ к элементу пары (шаблон функции) |
(C++17) |
читает значение variant по заданному индексу или типу (если тип уникален), генерирует исключение при ошибке (шаблон функции) |
(C++20) |
получает итератор или ограничитель из std::ranges::subrange (шаблон функции) |