std::ranges::views::counted

来自cppreference.com
< cpp‎ | ranges
 
 
 
在标头 <ranges> 定义
inline constexpr /*unspecified*/ counted = /*unspecified*/;
(C++20 起)
调用签名
template< class Iterator, class DifferenceType >

    requires /* see below */

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

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

计数范围 [i, n) 是始于以 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>
  • 否则,若 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 ,若 ef 拥有相同效果,均为潜在抛出或均非潜在抛出(即 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 的隐式转换可能非法 使之为显式

参阅

将迭代器/哨位对结合为一个 view
(类模板)
对到范围结尾距离进行跟踪的迭代器适配器
(类模板)
返回满足指定判别标准的元素数
(niebloid)