std::ranges::enumerate_view<V>::end
来自 cppreference.cn
< cpp | ranges | enumerate view
constexpr auto end() requires (!__simple_view<V>); |
(1) | (C++23 起) |
constexpr auto end() const requires /*range-with-movable-references*/<const V>; |
(2) | (C++23 起) |
返回一个与 enumerate_view
的末尾迭代器相等的 迭代器 或 哨兵。
设 base_
表示底层视图。
1) 等价于
if constexpr (ranges::forward_range<V> and ranges::common_range<V> and ranges::sized_range<V>) return /*iterator*/<false>(ranges::end(base_), ranges::distance(base_)); else return /*sentinel*/<false>(ranges::end(base_));
2) 等价于
if constexpr (ranges::forward_range<const V> and ranges::common_range<const V> and ranges::sized_range<const V>) return /*iterator*/<true>(ranges::end(base_), ranges::distance(base_)); else return /*sentinel*/<true>(ranges::end(base_));
目录 |
[编辑] 参数
(无)
[编辑] 返回值
一个 迭代器 或 哨兵,代表 enumerate_view
的末尾,如上所述。
[编辑] 示例
本节不完整 原因:无示例 |
[编辑] 缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
缺陷报告 | 应用于 | 发布时的行为 | 正确的行为 |
---|---|---|---|
LWG 3919 | C++23 | 对于有大小的公共 非前向底层范围, ranges::distance 可能会引发未定义行为。 |
对于此类范围,返回哨兵类型。 |
[编辑] 参阅
返回指向起始的迭代器 (公共成员函数) | |
(C++20) |
返回指示范围末尾的哨兵 (定制点对象) |