std::ranges::sized_range, std::ranges::disable_sized_range

来自cppreference.com
 
 
范围库
范围适配器
 
<tbody> </tbody> <tbody class="t-dcl-rev t-dcl-rev-num "> </tbody><tbody> </tbody>
在标头 <ranges> 定义
(1)
template< class T > concept sized_range = ranges::range<T> && requires(T& t) { ranges::size(t); };
(C++20 起)
(C++26 前)
template< class T > concept sized_range = ranges::approximately_sized_range<T> && requires(T& t) { ranges::size(t); };
(C++26 起)
template< class > constexpr bool disable_sized_range = false;
(2) (C++20 起)
1) sized_range 概念指定在常数时间内以 size 函数知晓其大小的 range(C++26 前)approximately_sized_range(C++26 起) 类型。
2) disable_sized_range 为允许使用(成员或非成员)提供 size 函数但不实际实现 sized_range 的范围类型存在。用户可对无 cv 限定的程序定义类型特化 disable_sized_range。这些特化应当可用于常量表达式并拥有 const bool 类型。

语义要求

1) 给定 std::remove_reference_t<T> 类型的左值 tT 只有在满足以下所有条件时才会实现 sized_range
  • ranges::size(t)
  • 拥有均摊的常数时间复杂度,
  • 不以对于保持相等性的表达式可观察的方式更改 t 的值,且
  • 等于 ranges::distance(ranges::begin(t), ranges::end(t)),并且
  • 如果 ranges::iterator_t<T> 实现了 forward_iterator,那么无论对 ranges::begin(t) 的求值的行为如何,ranges::size(t) 都具有良好定义(换言之,单趟有大小范围可以只在首次调用 begin 前支持调用 size,但向前范围必须在所有时间支持)。

注解

disable_sized_range 不能用于手动禁用迭代器与哨位满足 sized_sentinel_for 的范围;必须用 disable_sized_sentinel_for 代替。

不能对数组类型或引用类型特化 disable_sized_range

功能特性测试 标准 功能特性
__cpp_lib_ranges_reserve_hint 202502L (C++26) ranges::approximately_sized_rangeranges::reserve_hint

示例

#include <forward_list>
#include <list>
#include <ranges>

static_assert
(
    std::ranges::sized_range<std::list<int>> and
    not std::ranges::sized_range<std::forward_list<int>>
);

int main() {}

参阅

指定范围的迭代器类型满足 random_access_iterator
(概念) [编辑]
指定范围的迭代器类型满足 contiguous_iterator
(概念) [编辑]