标准库标头 <tuple> (C++11)

来自cppreference.com
< cpp‎ | header


 
 
标准库头
 

此头文件是通用工具库的一部分。

目录

包含

(C++20)
三路比较运算符支持[编辑]

(C++11)
实现固定大小的容器,可保有类型相异的元素
(类模板)[编辑]
(C++11)
获得元组式类型的元素数量
(类模板)[编辑]
获得元组式类型的元素类型
(类模板)[编辑]
获得 tuple 的大小
(类模板特化)[编辑]
获得指定元素的类型
(类模板特化)[编辑]
特化 std::uses_allocator 类型特征
(类模板特化)[编辑]

常量

(C++11)
tie 解包 tuple 时用来跳过元素的占位符
(常量)[编辑]

函数

(C++11)
创建一个 tuple 对象,其类型根据各实参类型定义
(函数模板)[编辑]
(C++11)
创建左值引用的 tuple,或将元组解包为独立对象
(函数模板)[编辑]
创建转发引用tuple
(函数模板)[编辑]
(C++11)
通过连接任意数量的元组来创建一个tuple
(函数模板)[编辑]
元组式访问指定的元素
(函数模板)[编辑]
(C++20 移除)(C++20 移除)(C++20 移除)(C++20 移除)(C++20 移除)(C++20)
按字典顺序比较 tuple 中的值
(函数模板)[编辑]
特化 std::swap 算法
(函数模板)[编辑]
(C++17)
以一个实参的元组来调用函数
(函数模板)[编辑]
以一个实参元组构造对象
(函数模板)[编辑]

[编辑]概要

#include <compare>   namespace std {// 类模板 tupletemplate<class... Types>class tuple;   // tuple 创建函数inlineconstexpr/* 未指定 */ ignore;   template<class... TTypes>constexpr tuple<unwrap_ref_decay_t<TTypes>...> make_tuple(TTypes&&...);   template<class... TTypes>constexpr tuple<TTypes&&...> forward_as_tuple(TTypes&&...)noexcept;   template<class... TTypes>constexpr tuple<TTypes&...> tie(TTypes&...)noexcept;   template<class... Tuples>constexpr tuple<CTypes...> tuple_cat(Tuples&&...);   // 以参数的 tuple 调用函数template<class F, class Tuple>constexpr decltype(auto) apply(F&& f, Tuple&& t);   template<class T, class Tuple>constexpr T make_from_tuple(Tuple&& t);   // tuple 辅助类template<class T>struct tuple_size;// 不定义template<class T>struct tuple_size<const T>;   template<class... Types>struct tuple_size<tuple<Types...>>;   template<size_t I, class T>struct tuple_element;// 不定义template<size_t I, class T>struct tuple_element<I, const T>;   template<size_t I, class... Types>struct tuple_element<I, tuple<Types...>>;   template<size_t I, class T>using tuple_element_t =typename tuple_element<I, T>::type;   // 元素访问template<size_t I, class... Types>constexpr tuple_element_t<I, tuple<Types...>>& get(tuple<Types...>&)noexcept;template<size_t I, class... Types>constexpr tuple_element_t<I, tuple<Types...>>&& get(tuple<Types...>&&)noexcept;template<size_t I, class... Types>constexprconst tuple_element_t<I, tuple<Types...>>& get(const tuple<Types...>&)noexcept;template<size_t I, class... Types>constexprconst tuple_element_t<I, tuple<Types...>>&& get(const tuple<Types...>&&)noexcept;template<class T, class... Types>constexpr T& get(tuple<Types...>& t)noexcept;template<class T, class... Types>constexpr T&& get(tuple<Types...>&& t)noexcept;template<class T, class... Types>constexprconst T& get(const tuple<Types...>& t)noexcept;template<class T, class... Types>constexprconst T&& get(const tuple<Types...>&& t)noexcept;   // 关系运算符template<class... TTypes, class... UTypes>constexprbool operator==(const tuple<TTypes...>&, const tuple<UTypes...>&);template<class... TTypes, class... UTypes>constexpr common_comparison_category_t</*synth-three-way-result*/<TTypes, UTypes>...> operator<=>(const tuple<TTypes...>&, const tuple<UTypes...>&);   // 分配器相关特征template<class... Types, class Alloc>struct uses_allocator<tuple<Types...>, Alloc>;   // 特化的算法template<class... Types>constexprvoid swap(tuple<Types...>& x, tuple<Types...>& y)noexcept(/* 见描述 */);   // tuple 辅助类template<class T>inlineconstexpr size_t tuple_size_v = tuple_size<T>::value;}   // 弃用namespace std {template<class T>class tuple_size<volatile T>;template<class T>class tuple_size<constvolatile T>;   template<size_t I, class T>class tuple_element<I, volatile T>;template<size_t I, class T>class tuple_element<I, constvolatile T>;}

[编辑]类模板 std::tuple

namespace std {template<class... Types>class tuple {public:// tuple 创建constexprexplicit(/* 见描述 */) tuple();constexprexplicit(/* 见描述 */) tuple(const Types&...);// 仅若 sizeof...(Types) >= 1template<class... UTypes>constexprexplicit(/* 见描述 */) tuple(UTypes&&...);// 仅若 sizeof...(Types) >= 1   tuple(const tuple&)=default; tuple(tuple&&)=default;   template<class... UTypes>constexprexplicit(/* 见描述 */) tuple(const tuple<UTypes...>&);template<class... UTypes>constexprexplicit(/* 见描述 */) tuple(tuple<UTypes...>&&);   template<class U1, class U2>constexprexplicit(/* 见描述 */) tuple(const pair<U1, U2>&);// 仅若 sizeof...(Types) == 2template<class U1, class U2>constexprexplicit(/* 见描述 */) tuple(pair<U1, U2>&&);// 仅若 sizeof...(Types) == 2   // allocator-extended constructorstemplate<class Alloc>constexprexplicit(/* 见描述 */) tuple(allocator_arg_t, const Alloc& a);template<class Alloc>constexprexplicit(/* 见描述 */) tuple(allocator_arg_t, const Alloc& a, const Types&...);template<class Alloc, class... UTypes>constexprexplicit(/* 见描述 */) tuple(allocator_arg_t, const Alloc& a, UTypes&&...);template<class Alloc>constexpr tuple(allocator_arg_t, const Alloc& a, const tuple&);template<class Alloc>constexpr tuple(allocator_arg_t, const Alloc& a, tuple&&);template<class Alloc, class... UTypes>constexprexplicit(/* 见描述 */) tuple(allocator_arg_t, const Alloc& a, const tuple<UTypes...>&);template<class Alloc, class... UTypes>constexprexplicit(/* 见描述 */) tuple(allocator_arg_t, const Alloc& a, tuple<UTypes...>&&);template<class Alloc, class U1, class U2>constexprexplicit(/* 见描述 */) tuple(allocator_arg_t, const Alloc& a, const pair<U1, U2>&);template<class Alloc, class U1, class U2>constexprexplicit(/* 见描述 */) tuple(allocator_arg_t, const Alloc& a, pair<U1, U2>&&);   // tuple 赋值constexpr tuple& operator=(const tuple&);constexpr tuple& operator=(tuple&&)noexcept(/* 见描述 */);   template<class... UTypes>constexpr tuple& operator=(const tuple<UTypes...>&);template<class... UTypes>constexpr tuple& operator=(tuple<UTypes...>&&);   template<class U1, class U2>constexpr tuple& operator=(const pair<U1, U2>&);// 仅若 sizeof...(Types) == 2template<class U1, class U2>constexpr tuple& operator=(pair<U1, U2>&&);// 仅若 sizeof...(Types) == 2   // tuple 交换constexprvoid swap(tuple&)noexcept(/* 见描述 */);};   template<class... UTypes> tuple(UTypes...)-> tuple<UTypes...>;template<class T1, class T2> tuple(pair<T1, T2>)-> tuple<T1, T2>;template<class Alloc, class... UTypes> tuple(allocator_arg_t, Alloc, UTypes...)-> tuple<UTypes...>;template<class Alloc, class T1, class T2> tuple(allocator_arg_t, Alloc, pair<T1, T2>)-> tuple<T1, T2>;template<class Alloc, class... UTypes> tuple(allocator_arg_t, Alloc, tuple<UTypes...>)-> tuple<UTypes...>;}
close