std::tuple_element<std::ranges::subrange>
来自 cppreference.cn
定义于头文件 <ranges> |
||
template< class I, class S, ranges::subrange_kind K > struct tuple_element<0, ranges::subrange<I, S, K>>; |
(1) | (since C++20) |
template< class I, class S, ranges::subrange_kind K > struct tuple_element<0, const ranges::subrange<I, S, K>>; |
(2) | (since C++20) |
template< class I, class S, ranges::subrange_kind K > struct tuple_element<1, ranges::subrange<I, S, K>>; |
(3) | (since C++20) |
template< class I, class S, ranges::subrange_kind K > struct tuple_element<1, const ranges::subrange<I, S, K>>; |
(4) | (since C++20) |
std::tuple_element 的针对 std::ranges::subrange 的部分特化提供了对 subrange
的迭代器或哨位类型进行编译时访问,使用类似元组的语法。它们为结构化绑定提供支持。
1,2) 获取迭代器类型,即
I
。3,4) 获取哨位类型,即
S
。内容 |
[编辑] 成员类型
成员类型 | 定义 |
type
|
(1,2) I (3,4) S |
[编辑] 注解
由于 subrange
的 get
函数按值返回迭代器和哨位,当 subrange
是 const 限定的(但不是 volatile 限定的)时候,const 限定符不会添加到结果类型。
如果 subrange
是 volatile 限定的,结果类型也会是 volatile 限定的,因为使用了 volatile 或 const volatile 类型的偏特化。这种用法已被弃用。
[编辑] 示例
运行此代码
#include <iterator> #include <list> #include <ranges> #include <type_traits> int main() { std::list<int> list{3, 1, 4, 1, 5, 9, 2, 6}; std::ranges::subrange subrange { std::counted_iterator{std::begin(list), 4}, std::default_sentinel }; static_assert( std::is_same_v< std::tuple_element_t<0, decltype(subrange)>, // implementation-defined type: std::counted_iterator<std::_List_iterator<int>> >); static_assert( std::is_same_v< std::tuple_element_t<1, decltype(subrange)>, std::default_sentinel_t >); }
[编辑] 参见
结构化绑定 (C++17) | 将指定的名称绑定到初始值设定项的子对象或元组元素 |
(C++11) |
获取类似元组的类型的元素类型 (类模板) |
获取 std::ranges::subrange 的大小 (类模板特化) |