命名空间
变体
操作

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

来自 cppreference.cn
< cpp‎ | ranges‎ | subrange
 
 
范围库 (Ranges library)
范围适配器 (Range adaptors)
 
 
定义于头文件 <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 是有大小的,这由默认模板实参决定。
2) 从迭代器和哨兵的类型推导出模板实参,同时指定了范围的大小。subrange 总是带大小的。
3) 从范围的类型推导出模板实参。如果可以从范围或其迭代器和哨兵获得大小,则 subrange 是有大小的。
4) 从范围的类型推导出模板实参,同时指定了范围的大小。subrange 总是带大小的。

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

[编辑] 注意

构造 subrange 对象时,

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

[编辑] 示例

[编辑] 缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 发布时的行为 正确的行为
LWG 3404 C++20 提供了无意义的 pair-like 类型推导指南 已移除