std::ranges::constant_range

来自cppreference.com
< cpp‎ | ranges
 
 
范围库
范围适配器
 
在标头 <ranges> 定义
template<class T >

concept constant_range =
    ranges::input_range<T>&&

    /*constant-iterator*/<ranges::iterator_t<T>>;
(1) (C++23 起)
辅助概念
template<class T >

concept /*constant-iterator*/=
    std::input_iterator<T>&&

    std::same_as<std::iter_const_reference_t<T>, std::iter_reference_t<T>>;
(2) (仅用于阐述*)
1) 概念 constant_range 是概念 range 的精化。对于满足它的范围,ranges::begin 返回常量迭代器
2) 当输入迭代器的间接操作结果是其常引用(隐含只读)时,概念 /*constant-iterator*/<T> 得到满足。

[编辑]示例

#include <ranges>#include <span>#include <string_view>#include <vector>   // 确保参数为常量范围的机制// 1) 重载集,其中可变版本委托给常量版本template<std::ranges::constant_range R>void takes_any_range1(R&& r){// R 必定为常量范围}   template<std::ranges::range R>void takes_any_range1(R&& r){ takes_any_range1(std::views::as_const(std::forward<R>(r)));}   // 2) 一个掩蔽其形参的函数模板template<std::ranges::range R>void takes_any_range2(R&& _r){auto r = std::views::as_const(std::forward<R>(_r));   // r 必定为常量范围// 不再使用 _r}   // 3) 一个递归调用自身的函数模板template<std::ranges::range R>void takes_any_range3(R&& r){ifconstexpr(std::ranges::constant_range<R>){// R 必定为常量范围// 放置实现于此}else takes_any_range3(std::views::as_const(std::forward<R>(r)));}   static_assert ( std::ranges::constant_range<conststd::vector<int>> and not std::ranges::constant_range<std::vector<int>> and std::ranges::constant_range<std::string_view> and not std::ranges::constant_range<std::span<int>> and std::ranges::constant_range<std::span<constint>> and not std::ranges::constant_range<conststd::span<int>>);   int main(){}
close