標準ライブラリヘッダ <tuple>
提供: cppreference.com
このヘッダは汎用ユーティリティライブラリの一部です。
クラス | ||
(C++11) | 異なる型の混在できる複数の要素を格納する固定サイズのコンテナを実装します (クラステンプレート) | |
コンパイル時に tuple のサイズを取得します (クラステンプレートの特殊化) | ||
指定された要素の型を取得します (クラステンプレートの特殊化) | ||
std::uses_allocator 型特性の特殊化 (クラステンプレートの特殊化) | ||
定数 | ||
tuple を tie で分解するときに要素をスキップするためのプレースホルダです (定数) | ||
関数 | ||
引数の型によって定義される型の tuple オブジェクトを作成します (関数テンプレート) | ||
左辺値参照の tuple を作成したり、タプルを個々のオブジェクトに分解したりします (関数テンプレート) | ||
転送参照の tuple を作成します (関数テンプレート) | ||
任意の数のタプルを連結して新たな tuple を作成します (関数テンプレート) | ||
タプルの指定された要素にアクセスします (関数テンプレート) | ||
タプル内の値を辞書的に比較します (関数テンプレート) | ||
(C++11) | std::swap アルゴリズムの特殊化 (関数テンプレート) | |
(C++17) | タプルを引数として使用して関数を呼びます (関数テンプレート) | |
(C++17) | タプルを引数として使用してオブジェクトを構築します (関数テンプレート) |
[編集]概要
namespace std {// class template tuple:template<class... Types>class tuple; // tuple creation functions:inlineconstexpr/*unspecified*/ ignore;template<class... Types>constexpr tuple<VTypes...> make_tuple(Types&&...);template<class... Types>constexpr tuple<Types...> forward_as_tuple(Types&&...)noexcept;template<class... Types>constexpr tuple<Types&...> tie(Types&...)noexcept;template<class... Tuples>constexpr tuple<CTypes...> tuple_cat(Tuples&&...); // calling a function with a tuple of argumentstemplate<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 helper classes:template<class T>class tuple_size;// undefinedtemplate<class T>class tuple_size<const T>;template<class T>class tuple_size<volatile T>;template<class T>class tuple_size<constvolatile T>;template<class... Types>class tuple_size<tuple<Types...>>; template<size_t I, class T>class tuple_element;// undefinedtemplate<size_t I, class T>class tuple_element<I, const 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>;template<size_t I, class... Types>class tuple_element<I, tuple<Types...>>; // element access: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; //relational operators:template<class... TTypes, class... UTypes>constexprbool operator==(const tuple<TTypes...>&, const tuple<UTypes...>&);template<class... TTypes, class... UTypes>constexprbool operator<(const tuple<TTypes...>&, const tuple<UTypes...>&);template<class... TTypes, class... UTypes>constexprbool operator!=(const tuple<TTypes...>&, const tuple<UTypes...>&);template<class... TTypes, class... UTypes>constexprbool operator>(const tuple<TTypes...>&, const tuple<UTypes...>&);template<class... TTypes, class... UTypes>constexprbool operator<=(const tuple<TTypes...>&, const tuple<UTypes...>&);template<class... TTypes, class... UTypes>constexprbool operator>=(const tuple<TTypes...>&, const tuple<UTypes...>&); // allocator-related traitstemplate<class... Types, class Alloc>struct uses_allocator<tuple<Types...>, Alloc>;// specialized algorithms:template<class... Types>constexprvoid swap(tuple<Types...>& x, tuple<Types...>& y)noexcept(x.swap(y));// tuple helper classestemplate<class T>constexpr size_t tuple_size_v = tuple_size<T>::value;}
[編集]クラステンプレート std::tuple
template<class... Types>class tuple {public:// tuple construction/*conditionally-explicit*/constexpr tuple();// only if sizeof...(Types) >= 1/*conditionally-explicit*/constexpr tuple(const Types&...);// only if sizeof...(Types) >= 1template<class... UTypes>/*conditionally-explicit*/constexpr tuple(UTypes&&...); tuple(const tuple&)=default; tuple(tuple&&)=default;template<class... UTypes>/*conditionally-explicit*/constexpr tuple(const tuple<UTypes...>&);template<class... UTypes>/*conditionally-explicit*/constexpr tuple(tuple<UTypes...>&&);// only if sizeof...(Types) == 2template<class U1, class U2>/*conditionally-explicit*/constexpr tuple(const pair<U1, U2>&);// only if sizeof...(Types) == 2template<class U1, class U2>/*conditionally-explicit*/constexpr tuple(pair<U1, U2>&&); // allocator-extended constructorstemplate<class Alloc>constexpr tuple(allocator_arg_t, const Alloc& a);template<class Alloc>/*conditionally-explicit*/constexpr tuple(allocator_arg_t, const Alloc& a, const Types&...);template<class Alloc, class... UTypes>/*conditionally-explicit*/constexpr 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>/*conditionally-explicit*/constexpr tuple(allocator_arg_t, const Alloc& a, const tuple<UTypes...>&);template<class Alloc, class... UTypes>/*conditionally-explicit*/constexpr tuple(allocator_arg_t, const Alloc& a, tuple<UTypes...>&&);template<class Alloc, class U1, class U2>/*conditionally-explicit*/constexpr tuple(allocator_arg_t, const Alloc& a, const pair<U1, U2>&);template<class Alloc, class U1, class U2>/*conditionally-explicit*/constexpr tuple(allocator_arg_t, const Alloc& a, pair<U1, U2>&&); // tuple assignmentconstexpr tuple& operator=(const tuple&);constexpr tuple& operator=(tuple&&)noexcept(see below );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>&);// only if sizeof...(Types) == 2template<class U1, class U2>constexpr tuple& operator=(pair<U1, U2>&&);// only if sizeof...(Types) == 2 // tuple swapconstexprvoid swap(tuple&)noexcept(/*conditional*/);};