std::ranges::views 是 C++20 提供的懒求值视图适配器集合,支持 filter、transform、take、drop、reverse、join 等操作,通过 | 管道链式组合,不拷贝数据、延迟计算,满足高效函数式数据处理需求。

std::ranges::views 是 C++20 中 <ranges></ranges> 头文件提供的懒求值视图适配器集合,用于以函数式风格组合、转换和过滤范围(ranges),不拷贝数据、不立即执行,只在迭代时按需计算。
以下是最常被使用的 views,覆盖过滤、变换、截取、拼接等核心场景:
auto evens = nums | views::filter([](int x) { return x % 2 == 0; });
auto squares = nums | views::transform([](int x) { return x * x; });
auto first5 = data | views::take(5);,auto rest = data | views::drop(3);
auto pos = nums | views::take_while([](int x) { return x > 0; });
auto reversed = vec | views::reverse;
vector<vector>></vector> → 扁平 int 序列)。views::transform 使用:outer | views::transform([](const auto& v) { return v; }) | views::join;
views::zip_transform 替代(需自行实现或借助第三方如 range-v3)。所有 views 支持链式组合,用 | 连接,从左到右执行,语义清晰且高效:
auto result = data<br> | views::filter(is_positive)<br> | views::transform(to_string)<br> | views::take(10);
不是所有 views 都适用于任意 range 类型:
立即学习“C++免费学习笔记(深入)”;
views::reverse 要求 range 是 bidirectional_range(如 std::vector、std::list),不适用于单向流(如 std::istringstream);views::join 要求内层 range 是 input_range,且所有内层 range 的 value_type 必须相同;views::common 可将非 common_range(如某些输入流)转为可存储的 range,便于赋值或传参;view 类型(即满足 std::ranges::view 概念),可直接用于 for-range 循环,但不可直接用 std::size() 获取大小(除非是 sized_range)。views::all 显式构造 view(尤其对 C 风格数组或临时 range):int arr[] = {1,2,3}; auto v = views::all(arr);
views::iota 生成整数序列(类似 Python 的 range):auto seq = views::iota(1) | views::take(5); // 1,2,3,4,5
std::ranges::to<:vector>()</:vector>(C++23)或手动 materialize。基本上就这些。掌握 filter / transform / take / drop / reverse / join 这几个,就能覆盖绝大多数日常数据流水线需求。组合灵活、零开销抽象,正是 ranges 的核心价值。
以上就是c++++中的std::ranges::views有哪些常用的_c++ C++20 Range库核心组件的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号