std::ranges::views::counted

来自cppreference.com
< cpp‎ | ranges
 
 
范围库
范围适配器
 
在标头 <ranges> 定义
inlineconstexpr/* 未指明 */ counted =/* 未指明 */;
(C++20 起)
调用签名
template<class Iterator, class DifferenceType >

    requires /* 见下文 */

constexpr/*span-or-subrange*/ counted( Iterator&& it, DifferenceType&& count );
(C++20 起)

计数视图是表示某迭代器 i 与非负整数 n计数范围[in) 的元素的 view

计数范围 [in) 是始于以 i 所指向的元素,直到但不包含应用 n++i 的结果所指向的元素的 n 个元素。

n ==0,则计数范围合法且为空。否则,计数范围仅若 n 为正,i 可解引用,且 [++i--n) 为合法的计数范围才合法。

正式而言,若 itcount 为表达式,Tstd::decay_t<decltype((it))>,而 Dstd::iter_difference_t<T>,则

T 实现 input_or_output_iteratordecltype((count)) 实现 std::convertible_to<D>
否则 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 的隐式转换可能非法 使之为显式

[编辑]参阅

由另一 view 的前 N 个元素组成的 view
(类模板)(范围适配器对象)[编辑]
将迭代器/哨位对结合为一个 view
(类模板)[编辑]
对到范围结尾距离进行跟踪的迭代器适配器
(类模板)[编辑]
返回满足特定条件的元素数目
(算法函数对象)[编辑]
close