C++20新增内容

news2025/4/6 12:28:00

C++20 是 C++ 语言的一次重大更新,它引入了许多新特性,使代码更现代化、简洁且高效。以下是 C++20 的主要新增内容:


1. 概念(Concepts)

概念用于约束模板参数,使模板编程更加直观和安全。

#include <concepts>
#include <iostream>

template <std::integral T>  // 约束 T 必须是整数类型
T add(T a, T b) {
    return a + b;
}

int main() {
    std::cout << add(3, 4) << "\n"; // OK
    // std::cout << add(3.5, 4.2); // 编译错误:double 不是整数
}

2. 范围库(Ranges)

C++20 引入了 std::ranges 以更优雅地操作序列。

#include <ranges>
#include <vector>
#include <iostream>

int main() {
    std::vector<int> v = {1, 2, 3, 4, 5};
    for (int x : v | std::views::filter([](int n) { return n % 2 == 0; })) {
        std::cout << x << " ";  // 输出: 2 4
    }
}

3. 协程(Coroutines)

C++20 引入了协程,使得异步编程更加高效。

#include <coroutine>
#include <iostream>

struct Task {
    struct promise_type {
        Task get_return_object() { return {}; }
        std::suspend_never initial_suspend() { return {}; }
        std::suspend_never final_suspend() noexcept { return {}; }
        void return_void() {}
        void unhandled_exception() {}
    };
};

Task example() {
    std::cout << "Hello, ";
    co_await std::suspend_always{};
    std::cout << "World!\n";
}

int main() {
    example();  // 输出: Hello,
}

4. std::span(轻量级数组视图)

std::span 提供更安全和高效的数组访问方式,无需拷贝数据。

#include <span>
#include <iostream>

void print(std::span<int> s) {
    for (int n : s) std::cout << n << " ";
}

int main() {
    int arr[] = {1, 2, 3, 4, 5};
    print(arr);  // 自动推导为 span
}

5. 三路比较运算符(<=>,Spaceship Operator)

引入三路比较运算符 operator<=>,简化比较运算符的定义。

#include <iostream>
#include <compare>

struct Point {
    int x, y;
    auto operator<=>(const Point&) const = default;  // 自动生成所有比较运算符
};

int main() {
    Point p1{1, 2}, p2{2, 3};
    std::cout << (p1 < p2) << "\n";  // 输出: 1 (true)
}

6. constexpr 关键字增强

C++20 允许 constexpr 函数包含 try-catch 语句和动态内存分配。

#include <vector>

constexpr int sum(const std::vector<int>& v) {
    int total = 0;
    for (int n : v) total += n;
    return total;
}

int main() {
    constexpr std::vector<int> v = {1, 2, 3, 4, 5};
    static_assert(sum(v) == 15);
}

7. 模块(Modules)

C++20 引入模块化机制,减少 #include 依赖,提高编译速度。

// mymodule.cpp
export module mymodule;
export int add(int a, int b) { return a + b; }

// main.cpp
import mymodule;
#include <iostream>

int main() {
    std::cout << add(3, 4) << "\n";  // 输出: 7
}

8. std::jthread(自动管理的线程)

C++20 引入 std::jthread,在析构时自动 join() 线程,防止资源泄露。

#include <thread>
#include <iostream>

int main() {
    std::jthread t([] { std::cout << "Running in thread\n"; });
}  // `t` 自动 `join()`,无需手动管理

9. std::bit_cast(高效的类型转换)

std::bit_cast<T>(value) 用于无损转换 POD 类型,无额外开销。

#include <bit>
#include <iostream>

int main() {
    float f = 3.14f;
    int i = std::bit_cast<int>(f);
    std::cout << i << "\n";  // 按位转换,无额外开销
}

10. std::format(格式化字符串)

类似 printf 的格式化 API,但更安全。

#include <format>
#include <iostream>

int main() {
    std::cout << std::format("Hello, {}!", "world") << "\n";  // 输出: Hello, world!
}

11. std::ranges::views::zip(打包多个容器)

C++20 提供 std::ranges::views::zip 让多个容器同步迭代。

#include <ranges>
#include <vector>
#include <iostream>

int main() {
    std::vector<int> a = {1, 2, 3};
    std::vector<std::string> b = {"one", "two", "three"};

    for (auto [x, y] : std::views::zip(a, b)) {
        std::cout << x << " -> " << y << "\n";
    }
}

12. std::stop_token(线程取消机制)

C++20 引入 std::stop_token,用于安全地取消线程。

#include <iostream>
#include <thread>
#include <stop_token>

void task(std::stop_token st) {
    while (!st.stop_requested()) {
        std::cout << "Working...\n";
        std::this_thread::sleep_for(std::chrono::milliseconds(500));
    }
}

int main() {
    std::jthread t(task);
    std::this_thread::sleep_for(std::chrono::seconds(2));
    t.request_stop();  // 取消线程
}

总结

C++20 是 C++11 以来最重要的一次更新,新增的特性大大提升了代码的 可读性、可维护性性能,主要包括:

  • 更好的模板编程:概念 (concepts)、if constexpr
  • 更现代的 STLstd::spanstd::formatstd::ranges
  • 更优雅的多线程支持std::jthreadstd::stop_token
  • 协程 (coroutines):支持 co_await 语法
  • 编译速度优化:模块 (modules)

C++20 提供了更现代化的编程方式,使开发更加 高效、安全,是值得学习和使用的版本!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2328379.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

分布式控制技术赋能智慧工厂精准控制研究

摘要&#xff1a;本文聚焦于分布式控制技术在智慧工厂精准控制中的应用。详细阐述了分布式控制系统&#xff08;DCS&#xff09;、边缘计算机、边边协同技术以及分布式计算等关键要素在实现精准控制中的作用机制。同时&#xff0c;分析了云边协同模式存在占用带宽、单点故障、数…

清明节里清明菜:软萩(拟人版介绍)

好像人们无论过任何节&#xff0c;总是离不开吃 清明节里吃清明菜&#xff0c;你采摘了吗&#xff1f; 姓名 软萩&#xff0c;也叫鼠麴草、清明菜、软雀&#xff0c;学名鼠曲草。 一些地方性小名&#xff08;防止大家找不到组织&#xff0c;已知的都附上&#xff09;&#xf…

JavaWeb学习--MyBatis-Plus整合SpringBoot的ServiceImpl方法(增加,修改与删除部分)

接下来是常用的增加&#xff0c;修改以及删除部分 首先是增加部分&#xff0c;增加一个新的数据 Testpublic void testInsert() {// 添加一个新用户记录Student s new Student();s.setName("NewStudent");s.setAge(25);boolean saved studentService.save(s);//可以…

AiCube 试用 - 创建流水灯工程

AiCube 试用 - 创建流水灯工程 本文介绍了 Aiapp-ISP 仿真调试平台软件的 AiCube 工具&#xff0c;实现流水灯工程的快速创建的主要流程。 下载运行 下载 最新版 AIapp-ISP 软件&#xff1b; 解压并打开该软件&#xff0c;右侧操作界面选择并进入 Keil 仿真设置 标签项&…

GISBox:核心功能免费的一站式三维GIS处理平台

大家好&#xff0c;今天为大家介绍的软件是GISBox&#xff1a;一款核心功能免费的一站式三维GIS处理平台&#xff0c;主要是适用于数字孪生。下面&#xff0c;我们将从软件的主要功能、支持的系统、软件官网等方面对其进行简单的介绍。 软件官网&#xff1a;http://www.gisbox.…

【论文笔记】DeepSeek-R1 技术报告

最强开源LLM&#xff0c;性能和效果都很棒&#xff1b;在数学、代码这种有标准正确答案的场景&#xff0c;表现尤为突出&#xff1b;一些其他场景的效果&#xff0c;可能不如DeepSeek-V3和Qwen。 Deepseek-R1没有使用传统的有监督微调sft方法来优化模型&#xff0c;而使用了大规…

基于javaweb的SSM羽毛球会员俱乐部系统场馆课程运动设计与实现(源码+文档+部署讲解)

技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;免费功能设计、开题报告、任务书、中期检查PPT、系统功能实现、代码编写、论文编写和辅导、论文…

[dp4_路径问题] 下降路径最小和 | 最小路径和 | 地下城游戏

目录 1.下降路径最小和 题解 2.最小路径和 题解 3.地下城游戏 题解 做算法题的时候&#xff0c;谨记图画得越详细越好&#xff0c;思路想的越清晰越好&#xff0c;然后再用代码实现一下就好啦 1.下降路径最小和 链接&#xff1a;931. 下降路径最小和 给你一个 n x n 的…

EasyExcel 数据字典转换器实战:注解驱动设计

一、场景痛点与解决方案 1. 问题背景 在 Excel 导入导出场景中&#xff0c;开发者常面临以下问题&#xff1a; 数据可读性差&#xff1a;数据库存储的字典值&#xff08;如 1、true&#xff09;直接导出时难以理解双向转换复杂&#xff1a;导入时需将用户输入的标签反向解析…

解决STM32CubeMX中文注释乱码

本人采用【修改系统环境变量】的方法 1. 使用快捷键 win X&#xff0c;打开【系统R】&#xff0c;点击【高级系统设置】 2. 点击【环境变量】 3. 点击【新建】 4.按图中输入【JAVA_TOOL_OPTIONS】和【-Dfile.encodingUTF-8】&#xff0c;新建环境变量后重启CubeMX即可。 解释…

AI产品的上层建筑:提示词工程、RAG与Agent

上节课我们拆解了 AI 产品的基础设施建设&#xff0c;这节课我们聊聊上层建筑。这部分是产品经理日常工作的重头戏&#xff0c;包含提示词、RAG 和 Agent 构建。 用 AI 客服产品举例&#xff0c;这三者的作用是这样的&#xff1a; 提示词能让客服很有礼貌。比如它会说&#x…

基于自定义注解+反射+AOP+Redis的通用开关设计:在投行交易与风控系统的落地实践

一句话总结&#x1f923; 一个注解让业务逻辑自动切换&#xff0c;Redis当起了隐形操盘手 业务痛点和需求场景 交易系统需支持毫秒级动态切换报价策略&#xff0c;如切换到备用流动性通道风控模型需支持灰度发布&#xff08;10%流量测试新权重算法&#xff09;和紧急熔断&am…

RK3588使用笔记:ubuntu/麒麟系统功能测试程序

一、前言 本编文章记录在使用嵌入式系统中的一些功能测试demo程序&#xff0c;大部分都是AI写的&#xff0c;哈哈哈&#xff0c;确实很有帮助&#xff0c;但是得根据自身设备实际情况和知道如何问AI&#xff0c;才能得出你想要的结果&#xff0c;本文就记录一些ubuntu/麒麟系统…

深度学习deeplearn3

# Jupyter Notebook魔法命令&#xff0c;用于在Notebook中内联显示图表 %matplotlib inline# 导入NumPy库&#xff0c;用于高效的数值计算 import numpy as np# 从matplotlib_inline库导入backend_inline模块&#xff0c;用于设置图表显示格式 from matplotlib_inline import b…

Mac强制解锁APP或文件夹

当Mac安装过火绒企业版、云安全访问服务之类的APP需要卸载的时候&#xff0c;会发现需要管理员密码&#xff0c;正常的卸载流程走不下去&#xff0c;直接删除APP&#xff0c;会提示“不能完成此操作&#xff0c;xxx已锁定”的信息&#xff0c;此处就记录一下如何关闭锁定状态&a…

SQL语句(二)—— DML

目录 一、添加数据 1、给指定字段添加数据 2、给全部字段添加数据 3、批量添加数据 二、修改数据 1、修改数据的具体语法 2、案例分析 3、注意事项 三、删除数据 1、删除数据的具体语法 2、案例 3、注意事项 DML全称是Data Manipulation Language&#xff0c;即数据…

Linux系统程序设计:从入门到高级Day02

这一篇 我带大家复习一下&#xff0c;C语言中的文件 那一部分 大家注意 这里的图并非原创 是当时我老师的图片 本片作用主要是 后续会有文件相关操作&#xff0c;这篇帮大家复习C语言文件中的内容 有助于大家后面的理解。 文章中代码大多是图片格式&#xff0c;是因为这是我…

快速掌握MCP——Spring AI MCP包教包会

最近几个月AI的发展非常快&#xff0c;各种大模型、智能体、AI名词和技术和框架层出不穷&#xff0c;作为一个业余小红书博主的我最近总刷到MCP这个关键字&#xff0c;看着有点高级我也来学习一下。 1.SpringAI与functionCall简单回顾 前几个月我曾写过两篇关于SpringAI的基础…

KUKA机器人查看运行日志的方法

对于KUKA机器人的运行日志都是可以查看和导出的&#xff0c;方便查找问题。KUKA机器人的运行日志查看方法如下&#xff1a; 1、在主菜单下&#xff0c;选择【诊断】-【运行日志】-【显示】下打开&#xff1b; 2、显示出之前的机器人运行日志&#xff1b; 3、也可以通过【过滤器…

MySQL 基础使用指南-MySQL登录与远程登录

MySQL 基础使用指南 1. 登录 MySQL 数据库的命令解析 命令格式&#xff1a; mysql -u用户名 -p密码参数说明&#xff1a; -u&#xff08;user 的缩写&#xff09;&#xff1a;指定登录用户。例如 -uroot 表示以 root 用户登录。-p&#xff08;password 的缩写&#xff09;&a…