std::ranges::views::counted
来自cppreference.com
在标头 <ranges> 定义 | ||
inlineconstexpr/* 未指明 */ counted =/* 未指明 */; | (C++20 起) | |
调用签名 | ||
template<class Iterator, class DifferenceType > requires /* 见下文 */ | (C++20 起) | |
计数视图是表示某迭代器 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) 非良构。
目录 |
定制点对象
名字 views::counted
代表一个定制点对象,它是某个字面semiregular
类类型的 const 函数对象。 细节参见定制点对象(CustomizationPointObject) 。
[编辑]注解
views::counted
并不检查范围长度是否足以提供全部 count 个元素:当必须检查时,应使用 views::take。
[编辑] 示例
运行此代码
#include <iostream>#include <ranges> int main(){constint a[]{1, 2, 3, 4, 5, 6, 7};for(int i : std::views::counted(a, 3))std::cout<< i <<' ';std::cout<<'\n'; constauto 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 的前 N 个元素组成的 view (类模板)(范围适配器对象) |
(C++20) | 将迭代器/哨位对结合为一个 view (类模板) |
(C++20) | 对到范围结尾距离进行跟踪的迭代器适配器 (类模板) |
(C++20)(C++20) | 返回满足特定条件的元素数目 (算法函数对象) |