std::ranges::take_view<V>:: end
|
constexpr
auto
end
(
)
requires
(
!
/*simple-view*/
<
V
>
)
;
|
(1) | (自 C++20 起) |
|
constexpr
auto
end
(
)
const
requires
ranges::
range
<
const
V
>
;
|
(2) | (自 C++20 起) |
返回一个哨兵或迭代器,表示
take_view
的结束位置。
take_view
的结束位置要么是底层范围中第
count
th
个元素之后的位置,要么是底层范围的结束位置(当后者包含的元素数量少于
count
时)。
当
V
是
简单视图
时(即当
V
和
const V
是具有相同迭代器和哨兵类型的视图时),重载
(1)
不参与重载决议。
目录 |
参数
(无)
返回值
结果取决于可能带有 const 限定符的底层视图类型
Base
所满足的概念,即对于
(
1
)
为
V
,对于
(
2
)
为
const V
。
令
base_
为底层视图。
|
底层视图类型
满足 ... |
random_access_range
|
||
|---|---|---|---|
| 是 | 否 | ||
sized_range
|
是 |
ranges::
begin
(
base_
)
+
ranges:: range_difference_t < Base_ > ( this - > size ( ) ) |
std:: default_sentinel |
| 否 |
1)
/*sentinel*/
<
false
>
{
ranges::
end
(
base_
)
}
2)
/*sentinel*/
<
true
>
{
ranges::
end
(
base_
)
}
|
||
示例
#include <iostream> #include <iterator> #include <list> #include <ranges> #include <type_traits> namespace ranges = std::ranges; namespace views = std::views; int main() { const auto list1 = {3, 1, 4, 1, 5}; const auto seq1{list1 | views::take(4)}; static_assert(ranges::sized_range<decltype(seq1)> and ranges::random_access_range<decltype(seq1)> and std::is_same_v<decltype(seq1.end()), decltype(list1.end())>); for (auto it = seq1.begin(); it != seq1.end(); ++it) std::cout << *it << ' '; std::cout << '\n'; std::list list2{2, 7, 1, 8, 2}; const auto seq2{list2 | views::take(4)}; static_assert(ranges::sized_range<decltype(seq2)> and not ranges::random_access_range<decltype(seq2)> and std::is_same_v<decltype(seq2.end()), std::default_sentinel_t>); for (auto it = seq2.begin(); it != std::default_sentinel; ++it) std::cout << *it << ' '; std::cout << '\n'; }
输出:
3 1 4 1 2 7 1 8
缺陷报告
下列行为变更缺陷报告被追溯应用于先前发布的C++标准。
| DR | 应用于 | 发布时的行为 | 正确行为 |
|---|---|---|---|
| P2393R1 | C++20 | 有符号和无符号整数类类型之间的隐式转换可能失败 | 改为显式转换 |
参见
|
返回指向起始位置的迭代器
(公开成员函数) |
|
|
(C++20)
|
追踪到范围末尾距离的迭代器适配器
(类模板) |
|
(C++20)
|
比较哨位与从
take_view::begin
返回的迭代器
(函数) |