std::ranges::views::take_while, std::ranges::take_while_view
来自cppreference.com
在标头 <ranges> 定义 | ||
template<ranges::view V, class Pred > requires ranges::input_range<V>&& | (1) | (C++20 起) |
namespace views { inlineconstexpr/* 未指定 */ take_while =/* 未指定 */; | (2) | (C++20 起) |
调用签名 | ||
template<ranges::viewable_range R, class Pred > requires /* 见下文 */ | (C++20 起) | |
template<class Pred > constexpr/* 范围适配器闭包 */ take_while( Pred&& pred ); | (C++20 起) | |
2)范围适配器对象(RangeAdaptorObject) 。表达式 views::take_while(e, f) 对任何适合的子表达式 e 与 f表达式等价于 take_while_view(e, f)。
take_while_view
分别在底层视图 V
实现 contiguous_range
、random_access_range
、bidirectional_range
、forward_range
和 input_range
时实现对应概念。
目录 |
[编辑]数据成员
成员 | 描述 |
V base_ (私有) | 底层视图 (仅用于阐述的成员对象*) |
copyable-box <Pred> (C++23 前)movable-box <Pred> (C++23 起)pred_ (私有) | 底层函数对象 (仅用于阐述的成员对象*) |
[编辑]成员函数
构造 take_while_view (公开成员函数) | |
返回底层(适配的)视图的副本 (公开成员函数) | |
返回到存储的谓词的引用 (公开成员函数) | |
返回指向起始的迭代器 (公开成员函数) | |
返回 表示末尾的哨位 (公开成员函数) | |
继承自 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> 的公开成员函数) | |
返回派生视图中的第 n 个元素,仅当视图满足 random_access_range 时提供 ( std::ranges::view_interface<D> 的公开成员函数) |
[编辑]推导指引
[编辑]嵌套类
哨位类型 (仅用于阐述的成员类模板*) |
[编辑]注解
对于 forward_iterator
,views::take_while(v, pred) 与 ranges::subrange{ranges::begin(v), ranges::find_if_not(v, pred)} 相似,但后者仅在构造过程中调用 pred,而前者每当将有效 take_while
迭代器与哨位相比较时都会调用 pred。
[编辑]示例
运行此代码
#include <iostream>#include <ranges> int main(){for(int year : std::views::iota(2020)| std::views::take_while([](int y){return y <2026;}))std::cout<< year <<' ';std::cout<<'\n'; constchar note[]{"Today is yesterday's tomorrow!..."};auto not_dot =[](char c){return c !='.';};for(char x : std::ranges::take_while_view(note, not_dot))std::cout<< x;std::cout<<'\n';}
输出:
2020 2021 2022 2023 2024 2025 Today is yesterday's tomorrow!
[编辑]参阅
(C++20) | 由另一 view 的前 N 个元素组成的 view (类模板)(范围适配器对象) |
由另一 view 跳过元素的起始序列,直至首个使谓词返回 false 的元素组成的 view (类模板)(范围适配器对象) |