0

0

c++20的范围库(Ranges)是什么 彻底改变你的for循环和算法使用【详解】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2025-12-22 09:46:54

|

633人浏览过

|

来源于php中文网

原创

c++20范围库是底层抽象范式升级,以range统一容器、迭代器与算法,支持惰性求值、组合式视图(如filter/transform)和简化for循环及算法调用。

c++20的范围库(ranges)是什么 彻底改变你的for循环和算法使用【详解】

C++20 的范围库(Ranges)不是“增强版 STL”,而是一次底层抽象范式的升级:它把“容器 + 迭代器 + 算法”三件套,统一成更自然、更组合化、更惰性求值的 范围(range) 概念。你不再需要手动传 begin()/end(),也不必担心迭代器失效或类型不匹配——for 循环和标准算法从此变得更像 Python 的 for item in list 或 Rust 的 iter().filter().map()。

什么是 range?不只是容器的别名

一个 range 是任何能通过 begin()end() 获得一对迭代器的对象(比如 vector、array、string),但关键在于:C++20 把这个概念正式纳入标准,并提供了统一接口和配套工具。它不等于容器,而是更高一层的抽象——比如子串视图(std::views::subrange)、过滤后视图(std::views::filter)、转换后视图(std::views::transform)都是 range,但它们本身不拥有数据,也不立即计算结果。

  • range 可以是 owning(如 vector)或 view(轻量、无拥有权、惰性)
  • view 是 range 的子集,要求常数时间构造/拷贝/移动,且不持有元素副本
  • 所有标准算法(如 sort、find、count)现在都有 range 版本(如 std::ranges::sort),直接接受 range,无需迭代器对

告别 begin/end:for 循环彻底简化

以前写循环要记住配对、类型一致、避免越界;现在只要对象是 range,就能直接用基于范围的 for:

std::vector<int> v = {1, 2, 3, 4, 5};
// 传统写法(冗余且易错)
for (auto it = v.begin(); it != v.end(); ++it) { /* ... */ }
<p>// C++20 写法(干净、安全、可读)
for (int x : v) { /<em> 直接用元素 </em>/ }</p><p>// 更进一步:直接遍历处理后的逻辑视图
for (int x : v | std::views::filter([](int n){ return n % 2 == 0; })
| std::views::transform([](int n){ return n * n; })) {
std::cout << x << ' '; // 输出 4 16(偶数的平方)
}

注意:| 是管道操作符(由 operator| 重载支持),让视图组合像 Unix 命令一样直观。整个链式表达式仍是 view,不会分配新容器,也不会立刻执行——直到你遍历它。

立即学习C++免费学习笔记(深入)”;

算法变“懒”了:std::ranges::xxx vs std::xxx

C++20 提供两套并行算法:老式 std::xxx(仍可用)和新式 std::ranges::xxx。后者有三大变化:

Dora
Dora

创建令人惊叹的3D动画网站,无需编写一行代码。

下载
  • 参数变简单:直接接收 range,自动提取 begin/end
  • 约束更严格:编译期检查 range 是否满足算法要求(如 sort 要求 random_access_range + sortable)
  • 返回类型更合理:例如 std::ranges::find 返回 iterator,而 std::ranges::find_if 也一样,不再有“返回 bool + out-param”的混乱设计

示例对比:

// C++17 及之前
auto it = std::find(v.begin(), v.end(), 42);
if (it != v.end()) { /* found */ }
<p>// C++20
if (auto res = std::ranges::find(v, 42); res != v.end()) { /<em> found </em>/ }
// 或更惯用:
if (std::ranges::find(v, 42) != v.end()) { ... }

常用 views 实战:filter、transform、take、drop、join

标准库提供了一组开箱即用的 view 适配器(定义在 <ranges></ranges> 中),它们是构建数据流水线的核心积木:

  • std::views::filter(pred):只保留满足谓词的元素(惰性,不复制)
  • std::views::transform(fn):对每个元素应用函数,生成新 view(不执行,仅描述)
  • std::views::take(n):取前 n 个;std::views::drop(n):跳过前 n 个
  • std::views::join:把 range of ranges(如 vector>)展平为单层 range
  • std::views::iota(start, end):生成 [start, end) 区间整数序列(类似 Python 的 range())

组合示例:

auto nums = std::views::iota(1, 100)
          | std::views::filter([](int x){ return x % 3 == 0 || x % 5 == 0; })
          | std::views::take(10);
<p>for (int x : nums) {
std::cout << x << ' '; // 输出前 10 个 3 或 5 的倍数:3 5 6 9 10 12 15 18 20 21
}

这段代码没有创建任何中间 vector,全程零堆分配,语义清晰,且可在编译期部分优化。

Ranges 不是语法糖,它是 C++ 向声明式、组合式、安全高效编程迈出的关键一步。它让算法更易读、更难写错、更容易复用。你不需要立刻重写全部代码,但从下一个新函数开始,试着用 std::ranges::| std::views::,你会很快感受到那种“本该如此”的流畅感。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
C++系统编程内存管理_C++系统编程怎么与Rust竞争内存安全
C++系统编程内存管理_C++系统编程怎么与Rust竞争内存安全

C++系统编程中的内存管理是指 对程序运行时内存的申请、使用和释放进行精细控制的机制,涵盖了栈、堆、静态区等不同区域,开发者需要通过new/delete、智能指针或内存池等方式管理动态内存,以避免内存泄漏、野指针等问题,确保程序高效稳定运行。它核心在于开发者对低层内存有完全控制权,带来灵活性,但也伴随高责任,是C++性能优化的关键。

13

2025.12.22

Rust异步编程与Tokio运行时实战
Rust异步编程与Tokio运行时实战

本专题聚焦 Rust 语言的异步编程模型,深入讲解 async/await 机制与 Tokio 运行时的核心原理。内容包括异步任务调度、Future 执行模型、并发安全、网络 IO 编程以及高并发场景下的性能优化。通过实战示例,帮助开发者使用 Rust 构建高性能、低延迟的后端服务与网络应用。

9

2026.02.11

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

219

2026.03.05

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1010

2023.08.02

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

203

2023.11.20

sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

409

2023.09.04

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1010

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

611

2024.08.29

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.9万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号