std::tuple_element<std::ranges::subrange>

来自cppreference.com
< cpp‎ | ranges‎ | subrange
 
 
范围库
范围访问
范围转换器
(C++23)
范围原语



悬垂迭代器处理
范围概念
视图

范围工厂
适配器
范围生成器
范围适配器对象
范围适配器闭包对象
辅助项
 
std::ranges::subrange
成员函数
观察器
迭代器操作
推导指引
非成员函数
(C++20)
辅助类型
(C++20)
tuple_element
(C++20)
 
在标头 <ranges> 定义
template< class I, class S, ranges::subrange_kind K >
struct tuple_element<0, ranges::subrange<I, S, K>>;
(1) (C++20 起)
template< class I, class S, ranges::subrange_kind K >
struct tuple_element<0, const ranges::subrange<I, S, K>>;
(2) (C++20 起)
template< class I, class S, ranges::subrange_kind K >
struct tuple_element<1, ranges::subrange<I, S, K>>;
(3) (C++20 起)
template< class I, class S, ranges::subrange_kind K >
struct tuple_element<1, const ranges::subrange<I, S, K>>;
(4) (C++20 起)

std::tuple_elementstd::ranges::subrange 的部分特化用元组式语法提供 subrange 的迭代器或哨位类型的编译时访问。它们是为结构化绑定支持提供的。

1-2) 获得迭代器类型,即 I
3-4) 获得哨位类型,即 S

成员类型

成员类型 定义
type (1-2) I
(3-4) S

注解

由于 subrangeget 函数按值返回迭代器与哨位,在 为 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)>,
            // 实现定义的类型:
            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) 绑定指定的名字到初始化器的子对象或元组元素
获得元组式类型的元素类型
(类模板)
获得 std::ranges::subrange 的组分数量
(类模板特化)