C++17 的编译器支持
来自 cppreference.cn
* - 悬停在标有星号 * 的单元格上,以查看其他弹出注释。
DRnn - "DR" 后的数字 nn 表示缺陷报告应用的目标 C++ 版本,例如,DR20 → C++20。
[编辑] C++17 核心语言特性
C++17 特性 |
论文 |
GCC |
Clang |
MSVC |
Apple Clang |
EDG eccp |
Intel C++ |
Nvidia HPC C++ (前 PGI)* |
Nvidia nvcc |
Cray |
Embarcadero C++ Builder |
IBM Open XL C++ for AIX |
|
---|---|---|---|---|---|---|---|---|---|---|---|---|---|
DR11:直接列表初始化的新 auto 规则 | N3922 | 5 | 3.8 | 19.0 (2015)* | 是 | 4.10.1 | 17.0 | 17.7 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
模板模板参数中的 typename | N4051 | 5 | 3.5 | 19.0 (2015)* | 是 | 4.10.1 | 17.0 | 17.7 | 是* | 11.0 | 10.3 | 17.1.0 | |
移除 三字符序列 | N4086 | 5 | 3.5 | 16.0* | 是 | 5.0 | 19.1 | 11.0 | 11.0 | 10.3 | 17.1.0 | ||
嵌套命名空间 定义 | N4230 | 6 | 3.6 | 19.0(Update 3)* | 是 | 4.12 | 17.0 | 17.7 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
无消息的 static_assert (FTM)* | N3928 | 6 | 2.5 | 19.10* | 是 | 4.12 | 18.0 | 17.7 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
命名空间和枚举器的 属性 (FTM)* (FTM)* | N4266 | 4.9(部分)* 6 |
3.6 | 19.0 (2015)* | 是 | 4.11 | 17.0 | 17.7 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
u8 字符字面量
|
N4267 | 6 | 3.6 | 19.0 (2015)* | 是 | 4.11 | 17.0 | 17.7 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
允许所有非类型模板参数的常量求值 (FTM)* | N4268 | 6 | 3.6 | 19.12* | 是 | 5.0 | 19.0.1 | 19.1 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
一元折叠表达式 和空参数包 | P0036R0 | 6 | 3.9 | 19.12* | 是 | 4.14 | 19.0 | 19.1 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
移除已弃用的 register 关键字的使用 | P0001R1 | 7 | 3.8 | 19.11* | 是 | 4.13 | 18.0 | 17.7 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
移除已弃用的 operator++(bool) | P0002R1 | 7 | 3.8 | 19.11* | 是 | 4.13 | 18.0 | 17.7 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
使异常规范成为类型系统的一部分 (FTM)* | P0012R1 | 7 | 4 | 19.12* | 是 | 4.14 | 19.0 | 19.1 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
预处理器条件中的 __has_include | P0061R1 | 5 | 是 | 19.11* | 是 | 4.13 | 18.0 | 17.7 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
DR11:继承构造函数 的新规范 (DR1941 等) (FTM)* | P0136R1 | 7 | 3.9 | 19.14** | 是 | 6.1 | 19.1 | 11.0 | 11.0 | 10.3 | 17.1.0 | ||
带有基类的 聚合类 (FTM)* | P0017R1 | 7 | 3.9 | 19.14* | 是 | 5.0 | 19.0.1 | 19.1 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
折叠表达式 (FTM)* | N4295 | 6 | 3.6 | 19.12* | 是 | 4.14 | 19.0 | 18.1 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
Lambda 捕获 *this (FTM)* | P0018R3 | 7 | 3.9 | 19.11* | 是 | 4.14 | 19.0 | 18.1 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
枚举的直接列表初始化 | P0138R2 | 7 | 3.9 | 19.11* | 是 | 4.14 | 18.0 | 19.1 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
constexpr lambda 表达式 (FTM)* |
P0170R1 | 7 | 5 | 19.11* | 是 | 4.14 | 19.0 | 18.1 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
基于范围的 for 循环 中不同的 begin 和 end 类型 (FTM)* | P0184R0 | 6 | 3.9 | 19.10* | 是 | 4.12 | 18.0 | 17.7 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
[[fallthrough]] 属性 |
P0188R1 | 7 | 3.9 | 19.10* | 是 | 4.13 | 18.0 | 17.7 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
[[nodiscard]] 属性 |
P0189R1 | 7 | 3.9 | 19.11* | 是 | 4.13 | 18.0 | 17.7 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
[[maybe_unused]] 属性 |
P0212R1 | 7 | 3.9 | 19.11* | 是 | 4.13 | 18.0 | 17.7 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
十六进制 浮点字面量 (FTM)* | P0245R1 | 3.0 | 是 | 19.11* | 是 | 4.13 | 18.0 | 17.7 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
使用没有重复的属性命名空间 | P0028R4 | 7 | 3.9 | 19.11* | 是 | 4.13 | 18.0 | 17.7 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
用于过度对齐数据的 动态内存分配 (FTM)* | P0035R4 | 7 | 4 | 19.12* | 10.0.0* | 4.14 | 19.0 | 19.1 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
具有 auto 类型的非类型模板参数 (FTM)* | P0127R2 | 7 | 4 | 19.14* | 是 | 5.0 | 19.0.1 | 19.1 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
保证的 复制省略 (FTM)* | P0135R1 | 7 | 4 | 19.13* | 是 | 5.0 | 19.0.1 | 19.1 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
包含引用成员的类对象的替换 | P0137R1 | 7 | 6 | 19.14* | 是 | 5.0 | 19.1 | 11.0 | 11.0 | 10.3 | 17.1.0 | ||
更严格的 表达式求值顺序 | P0145R3 | 7 | 4 | 19.14* | 是 | 5.0 | 19.0.1 | 19.1 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
结构化绑定 (FTM)* | P0217R3 | 7 | 4 | 19.11* | 是 | 4.14 | 19.0 | 18.1 | 11.0* | 11.0 | 10.3 | 17.1.0 | |
忽略未知的 属性 | P0283R2 | 是 | 3.9 | 19.0 (2015)* | 是 | 4.13 | 18.0 | 17.7 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
constexpr if 语句 (FTM)* | P0292R2 | 7 | 3.9 | 19.11* | 是 | 4.14 | 19.0 | 18.1 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
if 和 switch 的初始化语句 | P0305R1 | 7 | 3.9 | 19.11* | 是 | 4.14 | 18.0 | 18.1 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
内联变量 (FTM)* | P0386R2 | 7 | 3.9 | 19.12* | 是 | 4.14 | 19.0 | 18.1 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
移除 动态异常规范 | P0003R5 | 7 | 4 | 19.12* | 是 | 4.14 | 19.0 | 19.1 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
using 声明中的包展开 (FTM)* | P0195R2 | 7 | 4 | 19.14* | 是 | 5.0 | 19.0 | 19.1 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
DR98:模板模板参数的匹配排除兼容的模板 (FTM)* | P0522R0 | 7 | 4 | 19.12* | 是 | 5.0 | 19.0.1 | 19.1 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
类模板参数推导 (FTM)* | P0091R3 | 7 | 5 | 19.14* | 是 | 5.0 | 19.0.1 | 19.1 | 11.0 | 11.0 | 10.3 | 17.1.0 | |
C++17 特性 |
论文 |
GCC |
Clang |
MSVC |
Apple Clang |
EDG eccp |
Intel C++ |
Nvidia HPC C++ (前 PGI)* |
Nvidia nvcc |
Cray |
Embarcadero C++ Builder |
IBM Open XL C++ for AIX |
[编辑] C++17 库特性
C++17 特性 |
论文 |
GCC libstdc++ |
Clang libc++ |
MSVC STL |
Apple Clang* |
IBM Open XL C/C++ for AIX* |
Intel Parallel STL |
Embarcadero C++ Builder* |
|
---|---|---|---|---|---|---|---|---|---|
std::void_t (FTM)* | N3911 | 6.1 | 3.6 | 19.0 (2015)* | 是 | 17.1.0 | 不适用 | 10.3 | |
std::uncaught_exceptions() (FTM)* | N4259 | 6.1 | 3.7 | 19.0 (2015)* | 是 | 17.1.0 | 不适用 | 10.3 | |
std::size(), std::empty() 和 std::data() (FTM)* | N4280 | 6 | 3.6 | 19.0 (2015)* | 是 | 17.1.0 | 不适用 | 10.3 | |
std::allocator_traits::is_always_equal, noexcept 清理 (FTM)* | N4258 | 6.1 | 3.7 | 19.0 (2015)* | 17.1.0 | 不适用 | |||
std::invoke (FTM)* | N4169 | 6.1 | 3.7 | 19.0 (2015)* | 是 | 17.1.0 | 不适用 | ||
std::map::try_emplace, std::map::insert_or_assign (FTM)* | N4279 | 6.1 | 3.7 | 19.0 (2015)* | 是 | 17.1.0 | 不适用 | ||
std::unordered_map::try_emplace, std::unordered_map::insert_or_assign (FTM)* | N4279 | 6.1 | 3.7 | 19.0 (2015)* | 是 | 17.1.0 | 不适用 | ||
改进 std::pair 和 std::tuple | N4387 | 6.1 | 4 | 19.0(Update 2)* | 是 | 17.1.0 | 不适用 | 10.3 | |
std::bool_constant (FTM)* | N4389 | 6.1 | 3.7 | 19.0 (2015)* | 是 | 17.1.0 | 不适用 | 10.3 | |
std::shared_mutex (非定时) (FTM)* | N4508 | 6 | 3.7 | 19.0(Update 2)* | 是 | 17.1.0 | 不适用 | 10.3 | |
std::forward_list, std::list 和 std::vector 的最小不完整类型支持 (FTM)* | N4510 | 3.0 | 3.6 | 18.0* | 是 | 17.1.0 | 不适用 | ||
类型特征 变量模板 (FTM)* | P0006R0 | 7.1 | 3.8 | 19.0(Update 2)* | 是 | 17.1.0 | 不适用 | 10.3 | |
逻辑运算符类型特征 (FTM)* | P0013R1 | 6.1 | 3.8 | 19.0(Update 2)* | 是 | 17.1.0 | 不适用 | 10.3 | |
std::as_const (FTM)* | P0007R1 | 7.1 | 3.8 | 19.0(Update 2)* | 是 | 17.1.0 | 不适用 | ||
std::chrono::duration 和 std::chrono::time_point 的舍入函数 (FTM)* | P0092R1 | 7.1 | 3.8 | 19.0(Update 2)* | 是 | 17.1.0 | 不适用 | ||
透明 std::owner_less (std::owner_less<void>) (FTM)* | P0074R0 | 7.1 | 3.8 | 19.0(Update 2)* | 是 | 17.1.0 | 不适用 | ||
std::not_fn (FTM)* | P0005R4 P0358R1 |
7.1 | 3.9 | 19.12* | 是 | 17.1.0 | 不适用 | 10.3 | |
并行算法和 执行策略 (FTM)* (FTM)* | P0024R2 | 9* | 17 (部分)* |
19.14* | 18.0* | ||||
std::clamp() (FTM)* | P0025R1 | 7 | 3.9 | 19.0(Update 3)* | 10.0.0* | 17.1.0 | 不适用 | 10.3 | |
(不抛出异常)可交换的特征 (FTM)* | P0185R1 | 7.1* | 3.9 | 19.0(Update 3)* | 10.0.0* | 17.1.0 | 不适用 | 10.3 | |
多态内存资源 (FTM)* | P0220R1 | 9.1 | 16 | 19.13* | 15.0.0* | 17.1.1 | 不适用 | 10.3 | |
std::apply (FTM)* | P0220R1 | 7.1 | 16 | 19.13* | 是 | 17.1.0 | 不适用 | ||
搜索器 (FTM)* | P0220R1 | 7.1 | 16 | 19.13* | 是 | 17.1.0 | 不适用 | ||
std::sample (FTM)* | P0220R1 | 7.1 | 16 | 19.13* | 是 | 17.1.0 | 不适用 | ||
数学特殊函数 (FTM)* | P0226R1 | 7 | 19.14* | 17.1.1 | 不适用 | 10.3 | |||
constexpr std::addressof (FTM)* | LWG2296 | 7.1 | 是 | 19.0(Update 3)* | 17.1.0 | 不适用 | |||
constexpr 用于 std::reverse_iterator, std::move_iterator, std::array 和范围访问 (FTM)* | P0031R0 | 7.1 | 4 | 19.11* | 是 | 17.1.0 | 不适用 | ||
constexpr std::atomic<T>::is_always_lock_free (FTM)* | P0152R1 | 7.1 | 3.9 | 19.11* | 是 | 17.1.0 | 不适用 | ||
std::enable_shared_from_this::weak_from_this (FTM)* | P0033R1 | 7.1 | 3.9 | 19.12* | 是 | 17.1.0 | 不适用 | ||
std::hypot 的 3 参数重载 (FTM)* | P0030R1 | 7.1 | 3.9 | 19.14* | 是 | 17.1.0 | 不适用 | ||
std::byte (FTM)* | P0298R3 | 7 | 5 | 19.11* | 是 | 17.1.1 | 不适用 | 10.3 | |
std::string_view (FTM)* | N3921 P0220R1 P0254R2 P0403R1 |
7.1 | 4 | 19.10* (部分)* 19.11** |
10.0.0* | 17.1.0 | 不适用 | 10.3 | |
std::any (FTM)* | P0220R1 P0032R3 |
7.1 | 4 | 19.10* | 10.0.0* | 17.1.0 | 不适用 | 10.3 | |
std::optional (FTM)* | P0220R1 | 7.1 | 4 | 19.10* | 10.0.0* | 17.1.0 | 不适用 | 10.3 | |
C11 标准库的主要部分 | P0063R3 | 9.1 | 7 | 19.0 (2015)* (部分)* |
10.0.0* | 17.1.1 | 不适用 | ||
拼接 Maps 和 Sets (FTM)* | P0083R3 | 7 | 8 | 19.12* | 10.0.0* | 17.1.1 | 不适用 | ||
某些 容器 的 emplace* 函数的返回类型从 void 更改为引用 | P0084R2 | 7.1 | 4.0 | 19.11* | 是 | 17.1.0 | 不适用 | ||
std::variant (FTM)* | P0088R3 | 7.1 | 4 | 19.10* | 10.0.0* | 17.1.0 | 不适用 | 10.3 | |
std::make_from_tuple() (FTM)* | P0209R2 | 7.1 | 3.9 | 19.10* | 是 | 17.1.0 | 不适用 | 10.3 | |
std::has_unique_object_representations (FTM)* | P0258R2 | 7.1 | 6 | 19.11* | 是 | 17.1.1 | 不适用 | 10.3 | |
std::gcd() 和 std::lcm() (FTM)* | P0295R0 | 7 | 4 | 19.11* | 是 | 17.1.0 | 不适用 | 10.3 | |
CWG issue 1776: 包含引用成员的类对象的替换 (std::launder) (FTM)* | P0137R1 | 7.1 | 6 | 19.14* | 是 | 17.1.0 | 不适用 | ||
扩展内存管理工具 (FTM)* | P0040R3 | 7.1 | 4 | 19.11* | 17.1.0 | 不适用 | |||
shared_ptr::weak_type (FTM)* | P0163R0 | 7.1 | 3.9 | 19.10* | 是 | 17.1.0 | 不适用 | ||
基本字符串转换: std::to_chars / std::from_chars (FTM)* | P0067R5 | 8* 11 |
7* 14* 20* |
19.14** 19.24* |
10.0.0** | 17.1.1* | 不适用 | 10.3* | |
std::shared_ptr 和 std::weak_ptr 具有数组支持 | P0414R2 | 7 | 11 | 19.12* | 12.0.0* | 17.1.1 | 不适用 | 10.3 | |
std::chrono::duration 和 std::chrono::time_point 的所有成员函数的 constexpr (FTM)* | P0505R0 | 7.1 | 4 | 19.11* | 是 | 17.1.1 | 不适用 | ||
std::shared_ptr<T[]> (FTM)* | P0497R0 | 7.1 | 11 | 19.12* | 17.1.1 | 不适用 | |||
constexpr std::char_traits (FTM)* | P0426R1 | 8.1 | 4 | 19.14* | 是 | 17.1.1 | 不适用 | ||
文件系统库 (std::filesystem) (FTM)* | P0218R1 P0219R1 |
8 | 7 | 19.14* | 11.0.0* | 17.1.1 | 不适用 | 10.3 | |
硬件干扰大小 (FTM)* | P0154R1 | 12.1 | 15 (部分)* 19 |
19.11* | 不适用 | 10.3 | |||
std::scoped_lock (FTM)* | P0156R2 | 7 | 5 | 19.11* | 是 | 17.1.1 | 不适用 | 10.3 | |
std::is_aggregate (FTM)* | LWG2911 | 7 | 5 | 19.15* | 是 | 17.1.1 | 不适用 | 10.3 | |
std::is_invocable, std::invoke_result (FTM)* | P0604R0 | 7.1 | 是 | 19.11* | 是 | 17.1.1 | 不适用 | ||
DR17: std::hash<std::filesystem::path> | LWG3657 | 11.4 | 17 | 19.32* | 不适用 | ||||
C++17 特性 |
论文 |
GCC libstdc++ |
Clang libc++ |
MSVC STL |
Apple Clang* |
IBM Open XL C/C++ for AIX* |
Intel Parallel STL |
Embarcadero C++ Builder* |
[编辑] 注释
- 截至 2020-11-20,Oracle Developer Studio 的最新版本 是 12.6。它的文档 没有提及 C++17。
- Cray 编译器可能对某些特性的支持早于 11.0。 该版本是它成为 Clang 衍生版本的时间,获得了基础编译器的所有相关语言特性支持。 请参阅 Cray/HPE 文档 S-2179。