Namespaces
Variants
Views
Actions

Difference between revisions of "cpp/container/array/tuple element"

From cppreference.com
< cpp‎ | container‎ | array
m (Text replace - "{{example cpp" to "{{example")
m (fmt)
 
(22 intermediate revisions by 9 users not shown)
Line 1: Line 1:
 
{{cpp/title|tuple_element{{small|<std::array>}}}}
 
{{cpp/title|tuple_element{{small|<std::array>}}}}
{{cpp/container/array/sidebar}}
+
{{cpp/container/array/navbar}}
{{ddcl list begin}}
+
{{dcl begin}}
{{ddcl list header | array}}
+
{{dcl header|array}}
{{ddcl list item | notes={{mark since c++11}} | 1=
+
{{dcl|since=c++11|1=
 
template< std::size_t I, class T, std::size_t N >
 
template< std::size_t I, class T, std::size_t N >
struct tuple_element<I, array<T, N> >;
+
struct tuple_element< I, std::array<T, N> >;
 
}}
 
}}
{{ddcl list end}}
+
{{dcl end}}
  
Provides compile-type indexed access to the type of the elements of the array using tuple-like interface
+
Provides compile-time indexed access to the type of the elements of the array using tuple-like interface.
  
 
===Member types===
 
===Member types===
{{tdcl list begin}}
+
{{dsc begin}}
{{tdcl list hitem | Member type | Definition}}
+
{{dsc hitem|Member type|Definition}}
{{tdcl list item | type | the type of elements of the array}}
+
{{dsc|type|the type of elements of the array}}
{{tdcl list end}}
+
{{dsc end}}
  
 
===Possible implementation===
 
===Possible implementation===
{{eq fun cpp
+
{{eq fun
| 1=
+
|1=
 +
template<std::size_t I, class T>
 +
struct tuple_element;
 +
 
 +
template<std::size_t I, class T, std::size_t N>
 +
struct tuple_element<I, std::array<T,N>>
 +
{
 +
    using type = T;
 +
};
 
}}
 
}}
  
 
===Example===
 
===Example===
{{example |
+
{{example
| code=
+
|code=
| output=
+
#include <array>
 +
#include <tuple>
 +
#include <type_traits>
 +
 
 +
int main()
 +
{
 +
    // define array and get the type of the element at position 0
 +
    std::array<int, 10> data{0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
 +
    using T = std::tuple_element<0, decltype(data)>::type; // int
 +
    static_assert(std::is_same_v<T, int>);
 +
 
 +
    const auto const_data = data;
 +
    using CT = std::tuple_element<0, decltype(const_data)>::type; // const int
 +
 
 +
    // the result of tuple_element depends on the cv-qualification of the tuple-like type
 +
    static_assert(!std::is_same_v<T, CT>);
 +
    static_assert(std::is_same_v<CT, const int>);
 +
}
 
}}
 
}}
  
 
===See also===
 
===See also===
{{dcl list begin}}
+
{{dsc begin}}
{{dcl list template | cpp/utility/tuple/dcl list tuple_element}}
+
{{dsc inc|cpp/language/dsc structured binding}}
{{dcl list template | cpp/utility/pair/dcl list tuple_element}}
+
{{dsc inc|cpp/utility/tuple/dsc tuple_element}}
{{dcl list end}}
+
{{dsc inc|cpp/utility/pair/dsc tuple_element}}
 +
{{dsc end}}
 +
 
 +
{{langlinks|de|es|fr|it|ja|pt|ru|zh}}

Latest revision as of 13:47, 6 December 2023

 
 
 
 
Defined in header <array>
template< std::size_t I, class T, std::size_t N >
struct tuple_element< I, std::array<T, N> >;
(since C++11)

Provides compile-time indexed access to the type of the elements of the array using tuple-like interface.

Contents

[edit] Member types

Member type Definition
type the type of elements of the array

[edit] Possible implementation

template<std::size_t I, class T>
struct tuple_element;
 
template<std::size_t I, class T, std::size_t N>
struct tuple_element<I, std::array<T,N>>
{
    using type = T;
};

[edit] Example

#include <array>
#include <tuple>
#include <type_traits>
 
int main()
{
    // define array and get the type of the element at position 0
    std::array<int, 10> data{0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
    using T = std::tuple_element<0, decltype(data)>::type; // int
    static_assert(std::is_same_v<T, int>);
 
    const auto const_data = data;
    using CT = std::tuple_element<0, decltype(const_data)>::type; // const int
 
    // the result of tuple_element depends on the cv-qualification of the tuple-like type
    static_assert(!std::is_same_v<T, CT>);
    static_assert(std::is_same_v<CT, const int>);
}

[edit] See also

Structured binding (C++17) binds the specified names to sub-objects or tuple elements of the initializer[edit]
obtains the type of the specified element
(class template specialization) [edit]
obtains the type of the elements of pair
(class template specialization) [edit]