std::get(std::tuple)

来自cppreference.com
< cpp‎ | utility‎ | tuple
 
 
工具库
语言支持
类型支持(基本类型、RTTI)
库功能特性测试宏 (C++20)
动态内存管理
程序工具
协程支持 (C++20)
变参数函数
调试支持
(C++26)
三路比较
(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++14)
(C++11)
(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 起)
(C++14 起为 constexpr)
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 起)
(C++14 起为 constexpr)
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 起)
(C++14 起为 constexpr)
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 起)
(C++14 起为 constexpr)
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 个元素。I 必须是 [0sizeof...(Types)) 中的整数值。
5-8) 提取元组 t 中类型是 T 的元素。如果元组不恰好拥有一个该类型元素,那么编译失败。

参数

t - 要提取内容的元组

返回值

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::get 会生成到 std::get<std::variant> 的错误链接
    using std::get;
 
    // 基于索引的访问
    std::cout << "( " << get<0>(t)
              << ", " << get<1>(t)
              << ", " << get<2>(t)
              << " )\n";
 
    // 基于类型的访问(C++14 起)
    std::cout << "( " << get<int>(t)
              << ", " << get<const char*>(t)
              << ", " << get<double>(t)
              << " )\n";
 
    // 注意:std::tie 和结构化绑定也可以用来分解元组
}

输出:

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

缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 出版时的行为 正确行为
LWG 2485 C++11(按索引)
C++14(按类型)
没有对于 const tuple&& 的重载 添加这些重载

参阅

结构化绑定 (C++17) 绑定指定的名字到初始化式的子对象或元组元素
访问 array 的一个元素
(函数模板)
访问 pair 的一个元素
(函数模板)
以给定索引或类型(如果类型唯一)读取 variant 的值,错误时抛出异常
(函数模板)
std::ranges::subrange 获得迭代器或哨位
(函数模板)
std::complex 获取到实部或虚部的引用
(函数模板)