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

来自cppreference.com
< cpp‎ | ranges‎ | chunk view
 
 
范围库
范围适配器
 
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 起)

返回比较等于 chunk_view 的尾迭代器的 iteratorstd::default_sentinel

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 的末尾的迭代器或哨位,如上所述。

示例

参阅

返回指向起始的迭代器
(公开成员函数)
返回指示范围结尾的哨位
(定制点对象)