命名空间
变体
操作

std::ranges::subrange 的推导指引

来自 cppreference.cn
< cpp‎ | ranges‎ | subrange
 
 
范围库
范围适配器
 
 
定义于头文件 <ranges>
template< std::input_or_output_iterator I, std::sentinel_for<I> S >
subrange(I, S) -> subrange<I, S>;
(1) (自 C++20 起)
template< std::input_or_output_iterator I, std::sentinel_for<I> S >

subrange(I, S, /*make-unsigned-like-t*/<std::iter_difference_t<I>>) ->

    subrange<I, S, ranges::subrange_kind::sized>;
(2) (自 C++20 起)
template< ranges::borrowed_range<R> >

subrange(R&&) ->
    subrange<ranges::iterator_t<R>, ranges::sentinel_t<R>,
             (ranges::sized_range<R> ||
              std::sized_sentinel_for<ranges::sentinel_t<R>,
              ranges::iterator_t<R>>) ?

             ranges::subrange_kind::sized : ranges::subrange_kind::unsized>;
(3) (自 C++20 起)
template< ranges::borrowed_range<R> >

subrange(R&&, /*make-unsigned-like-t*/<ranges::range_difference_t<R>>) ->
    subrange<ranges::iterator_t<R>, ranges::sentinel_t<R>,

             ranges::subrange_kind::sized>;
(4) (自 C++20 起)

这些是为 std::ranges::subrange 提供的推导指引

1) 从迭代器和哨位类型推导模板实参。如果满足 std::sized_sentinel_for<S, I>,则 subrange 是有大小的(sized),由默认模板实参确定。
2) 从迭代器和哨位类型推导模板实参,同时指定范围的大小。 subrange 始终是有大小的(sized)。
3) 从范围类型推导模板实参。如果可以从范围或其迭代器和哨位获得大小,则 subrange 是有大小的(sized)。
4) 从范围类型推导模板实参,同时指定范围的大小。 subrange 始终是有大小的(sized)。

有关 /* make-unsigned-like-t */ 的定义,请参见 make-unsigned-like-t 。

[编辑] 注解

当构造 subrange 对象时,

  • 对于 (1,2),如果迭代器-哨位对未表示有效范围,则行为是未定义的,
  • 对于 (2,4),如果给定的大小与范围的大小不相等,则行为是未定义的。

[编辑] 示例

[编辑] 缺陷报告

以下行为变更缺陷报告被追溯应用于先前发布的 C++ 标准。

DR 应用于 已发布行为 正确行为
LWG 3404 C++20 提供了来自类对类型(pair-like types)的无意义推导指引 已移除