C++17和C++20引入的新特性

C++17

if constexpr

在编译的时候可以来决定是否编译某段代码,从而避免在运行的时候引入不必要的计算

template<typename T>
void print_type() {
    if constexpr (std::is_integral<T>::value) {
        std::cout << "Integral type\n";
    } else {
        std::cout << "Non-integral type\n";
    }
}

结构化绑定声明

指的是允许将元组或者多个返回值直接解构,越来越像python了

std::tuple<int, double, std::string> get_values() {
    return {42, 3.14, "Hello"};
}

auto [x, y, z] = get_values();  // 直接解构

std::variant

允许变量持有多种不同类型,但只持有一个类型的值

std::variant<int, float> v = 10;
if (std::holds_alternative<int>(v)) {
    std::cout << "It's an int: " << std::get<int>(v) << "\n";
}

对STL提供并行策略

#include <algorithm>
#include <vector>
#include <execution>

std::vector<int> v = {1, 2, 3, 4, 5};
std::for_each(std::execution::par, v.begin(), v.end(), [](int& n) { n *= 2; });

增强模板推导能力

C++20新特性

支持协程

协程很多视频都讲不清楚,大致总结了几种看法:

  1. 认为协程能够进行用户态线程的切换,避免陷入内核后才能进行线程切换
  2. 解决了回调地狱的情况
  3. 类似future + promise

引入likely/ unlikely

用于向编译器提示某个分支可能是常见或者不常见的,从而帮助优化分支预测

if (condition) [[likely]] {
    // 可能是常见的分支
} else [[unlikely]] {
    // 可能是少见的分支
}

concept

用于约束模板类型,只接受模板参数类型为限定范围,从而增强安全性。

template<typename T>
concept Integral = std::is_integral<T>::value;

在这里Integral即代表long、short、int等等,在使用的时候为

template<Integral T>
T add(T a, T b) {
    return a + b;
}

接受参数是整数类型,如果传入的不满足这个类型,则编译器会报错。

总结

总的来说,C++17是扩充了语言的灵活度,长得越来越像python了。C++20更为革命性的特征是协程、概念、模块等,出于性能和安全做了优化。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值