std::ranges::views::counted
在标头 <ranges> 定义
|
||
inline constexpr /*unspecified*/ counted = /*unspecified*/; |
(C++20 起) | |
调用签名 |
||
template< class Iterator, class DifferenceType > requires /* see below */ |
||
counted
视图是表示某迭代器 i
与非负整数 n
的计数范围 [i, n)
的元素的 view
。
计数范围 [i, n)
是始于以 i
所指向的元素,到若存在则为应用 n
次 ++i 的结果所指向的元素为止,但不包含该元素的 n
个元素。
若 n == 0 ,则计数范围合法且为空。否则,计数范围仅若 n
为正, i
可解引用,且 [++i, --n) 为合法的计数范围才合法。
正式而言,若 it 与 count 为表达式, T
为 std::decay_t<decltype((it))> ,而 D
为 std::iter_difference_t<T> ,则
- 若
T
实现input_or_output_iterator
且 decltype((count)) 实现 std::convertible_to<D> ,- 否则,若
T
实现contiguous_iterator
,则 views::counted(it, count) 表达式等价于 std::span(it, static_cast<std::size_t>(static_cast<D>(count))) ,否则 - 若
T
实现random_access_iterator
,则 views::counted(it, count) 表达式等价于 ranges::subrange(it, it + static_cast<D>(count)) ,否则 - views::counted(it, count) 表达式等价于 ranges::subrange(std::counted_iterator(it, count), std::default_sentinel)
- 否则,若
- 否则 views::counted(it, count) 非良构。
表达式等价
表达式 e 表达式等价于表达式 f ,若 e 与 f 拥有相同效果,均为潜在抛出或均非潜在抛出(即 noexcept(e) == noexcept(f) ),且均为常量子表达式或均非常量子表达式。
定制点对象
名字 views::counted
代表一个定制点对象,它是字面 semiregular
类类型的 const 函数对象。为说明目的,以 __counted_fn
表示它的类型的 cv 无限定版本。
__counted_fn
的所有实例均相等。在相同参数上调用类型 __counted_fn
的不同实例的效果是等价的,与指代该实例的表达式是左值还是右值,以及是否为 const 限定无关(然而不要求 volatile 限定的实例可调用)。从而能自由地复制 views::counted
并且能彼此替代地使用它的副本。
给定类型集合 Args...
,如果 std::declval<Args>()... 满足上面对于 views::counted
的参数要求,那么 __counted_fn
实现
- std::invocable<__counted_fn, Args...>、
- std::invocable<const __counted_fn, Args...>、
- std::invocable<__counted_fn&, Args...> 和
- std::invocable<const __counted_fn&, Args...>。
否则,__counted_fn
的函数调用运算符不会参与重载决议。
示例
#include <ranges> #include <iostream> int main() { const int a[] = {1, 2, 3, 4, 5, 6, 7}; for(int i : std::views::counted(a, 3)) std::cout << i << ' '; std::cout << '\n'; const auto il = {1, 2, 3, 4, 5}; for (int i : std::views::counted(il.begin() + 1, 3)) std::cout << i << ' '; std::cout << '\n'; }
输出:
1 2 3 2 3 4
缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
缺陷报告 | 应用于 | 出版时的行为 | 正确行为 |
---|---|---|---|
P2393R1 | C++20 | 从整数类类型到 size_t 的隐式转换可能非法
|
使之为显式 |
参阅
(C++20) |
将迭代器/哨位对结合为一个 view (类模板) |
(C++20) |
对到范围结尾距离进行跟踪的迭代器适配器 (类模板) |
(C++20)(C++20) |
返回满足指定判别标准的元素数 (niebloid) |