命名空间
变体
操作

std::ranges::chunk_view<V>::end

来自 cppreference.cn
< cpp‎ | ranges‎ | chunk_view
 
 
范围库 (Ranges library)
范围适配器 (Range adaptors)
 
std::ranges::chunk_view
成员函数
chunk_view::end
input_range 的类
推导指引
outer-iterator
outer-iterator::value_type
inner-iterator
 
V 仅支持 input_range
constexpr std::default_sentinel_t end() const noexcept;
(1) (C++23 起)
V 支持 forward_range
constexpr auto end() requires (!__simple_view<V>);
(2) (C++23 起)
constexpr auto end() const requires ranges::forward_range<const V>;
(3) (C++23 起)

返回一个 迭代器 (iterator) 或一个 std::default_sentinel,它们与 chunk_view 的结束迭代器比较相等。

1) 仅当 V 支持 input_range 时可用。等价于: return std::default_sentinel
2,3)V 支持 forward_range 时可用。设 base_ 表示底层被适配的视图,n_ 表示存储的块大小,iterator 表示嵌套的迭代器类。
2) 等价于
if constexpr (ranges::common_range<V> && ranges::sized_range<V>)
{
    auto missing = (n_ - ranges::distance(base_) % n_) % n_;
    return iterator<false>(this, ranges::end(base_), missing);
}
else if constexpr (ranges::common_range<V> && !ranges::bidirectional_range<V>)
    return iterator<false>(this, ranges::end(base_));
else
    return std::default_sentinel;
3) 等效于
if constexpr (ranges::common_range<const V> && ranges::sized_range<const V>)
{
    auto missing = (n_ - ranges::distance(base_) % n_) % n_;
    return iterator<true>(this, ranges::end(base_), missing);
}
else if constexpr (ranges::common_range<const V> && !ranges::bidirectional_range<const V>)
    return iterator<true>(this, ranges::end(base_));
else
    return std::default_sentinel;

[编辑] 返回值

一个迭代器或哨兵,表示 chunk_view 的结束,如上所述。

[编辑] 示例

[编辑] 参阅

返回指向起始的迭代器
(public member function) [编辑]
返回指示范围末尾的哨兵
(customization point object)[编辑]