std::ranges::views::to_input, std::ranges::to_input_view
来自cppreference.com
在标头 <ranges> 定义 | ||
template<ranges::input_range V > requires ranges::view<V> | (1) | (C++26 起) |
namespace views { inlineconstexpr/* 未指明 */ to_input =/* 未指明 */; | (2) | (C++26 起) |
调用签名 | ||
template<ranges::viewable_range R > requires /* 见下文 */ | (C++26 起) | |
2)范围适配器对象(RangeAdaptorObject) 。令 e 为子表达式,并令 T 为 decltype(e)。那么表达式 views::to_input(e)表达式等价于:
- views::all(e),如果它是良构表达式并且以下条件都为 true:
T
实现input_range
,T
不满足common_range
,以及T
不满足forward_range
。
- 否则为 to_input_view{e}。
结果是,to_input_view
从不实现任何比 input_range
更强的范围概念。特别是,它不实现以下任何概念:
此外,to_input_view
也不实现 common_range
。然而,当其底层视图 V
实现 borrowed_range
、constant_range
和 sized_range
时,它也实现相应的概念。
目录 |
[编辑]数据成员
成员 | 描述 |
V base_ (私有) | 底层视图 (仅用于阐述的成员对象*) |
[编辑]成员函数
构造 to_input_view (公开成员函数) | |
返回底层(适配的)视图的副本 (公开成员函数) | |
返回指向起始的迭代器 (公开成员函数) | |
返回指向末尾的迭代器或哨位 (公开成员函数) | |
返回元素数。仅当底层(适配的)范围满足 sized_range 时才提供。 (公开成员函数) | |
继承自 std::ranges::view_interface | |
返回视图是否为空,仅当视图满足 forward_range 时提供 ( std::ranges::view_interface<D> 的公开成员函数) | |
(C++23) | 返回指向范围起始的常量迭代器 ( std::ranges::view_interface<D> 的公开成员函数) |
(C++23) | 返回对应于范围常量迭代器的哨位 ( std::ranges::view_interface<D> 的公开成员函数) |
返回派生视图是否为非空,仅当 ranges::empty 可应用于它时提供 ( std::ranges::view_interface<D> 的公开成员函数) | |
返回派生视图的数据的地址,仅当视图的迭代器类型满足 contiguous_iterator 时提供 ( std::ranges::view_interface<D> 的公开成员函数) | |
返回派生视图中的首元素,仅当视图满足 forward_range 时提供 ( std::ranges::view_interface<D> 的公开成员函数) | |
返回派生视图中的末元素,仅当视图满足 bidirectional_range 与 common_range 时提供 ( std::ranges::view_interface<D> 的公开成员函数) | |
返回派生视图中的第 n 个元素,仅当视图满足 random_access_range 时提供 ( std::ranges::view_interface<D> 的公开成员函数) |
std::ranges::to_input_view::to_input_view
to_input_view() requires std::default_initializable<V>=default; | (1) | (C++26 起) |
constexprexplicit to_input_view( V base ); | (2) | (C++26 起) |
1) 以默认成员初始化器(= V())值初始化
base_
。2) 以 std::move(base) 初始化
base_
。参数
base | - | 一个视图 |
std::ranges::to_input_view::base
constexpr V base()const& requires std::copy_constructible<V>; | (1) | (C++26 起) |
constexpr V base()&&; | (2) | (C++26 起) |
1) 从底层视图复制构造结果。等价于 return base_;。
2) 从底层视图移动构造结果。等价于 return std::move(base_);。
std::ranges::to_input_view::begin
constexprauto begin() requires (!__simple_view<V>); | (1) | (C++26 起) |
constexprauto begin()const requires ranges::range<const V>; | (2) | (C++26 起) |
1) 等价于 return/*iterator*/<false>(ranges::begin(base_));
2) 等价于 return/*iterator*/<true>(ranges::begin(base_));
std::ranges::to_input_view::end
constexprauto end() requires (!__simple_view<V>); | (1) | (C++26 起) |
constexprauto end()const requires ranges::range<const V>; | (2) | (C++26 起) |
1,2) 等价于 returnranges::end(base_);
std::ranges::to_input_view::size
constexprauto size() requires ranges::sized_range<V>; | (1) | (C++26 起) |
constexprauto size()const requires ranges::sized_range<const V>; | (2) | (C++26 起) |
1,2) 等价于 returnranges::size(base_);
[编辑]推导指引
template<class R > to_input_view( R&&)-> to_input_view<views::all_t<R>>; | (C++26 起) | |
[编辑]嵌套类
the iterator type (仅用于阐述的成员类模板*) |
[编辑]辅助模板
template<class T > constexprbool enable_borrowed_range<std::ranges::to_input_view<T>>= | (C++26 起) | |
std::ranges::enable_borrowed_range 的这个特化使得 to_input_view
在底层视图满足 borrowed_range
时也满足它。
[编辑]注解
to_input_view
可用于避免为提供更强的迭代器强度而必须的开销。
功能特性测试宏 | 值 | 标准 | 功能特性 |
---|---|---|---|
__cpp_lib_ranges_to_input | 202502L | (C++26) | std::ranges::to_input_view |
[编辑]示例
本节未完成 原因:暂无示例 |
[编辑]参阅
(C++20) | 指定范围的迭代器类型满足 input_iterator (概念) |
转换 view 为 common_range (类模板)(范围适配器对象) |