C++17
來自 cppreference.com
< cpp
C++17 是一個主要版本,它緊隨次要版本 C++14 之後,並引入了新的語言和庫特性。該標準於 2017 年 12 月釋出。
以下特性已合併到 C++17 中:
- 來自 檔案系統 TS:檔案系統庫。
- 來自 庫基礎 v1 TS:包括 std::any、std::optional、std::string_view、std::apply、多型分配器、搜尋器 等特性。
- 來自 庫基礎 v2 TS:std::void_t、std::conjunction、std::disjunction、std::negation、std::not_fn、std::gcd、std::lcm。
- 來自 並行性 v1 TS:包括 執行策略、std::reduce、std::inclusive_scan、std::exclusive_scan 等特性,但移除了
exception_list
。 - 來自 數學特殊函式 IS:數學特殊函式。
- 來自 C11:std::aligned_alloc、std::timespec_get。
本節不完整 |
目錄 |
[編輯] 過時特性
[編輯] 移除特性
- std::auto_ptr,
- 棄用的函式物件,
- std::random_shuffle,
- std::unexpected,
- 過時的
iostream
別名, - 三字母詞,
- register 關鍵字,
-
bool
增量, - 動態異常規範
[編輯] 棄用特性
- std::iterator,
- std::raw_storage_iterator,
- std::get_temporary_buffer,
- std::is_literal_type,
- std::result_of,
- 所有 <codecvt>
[編輯] 新語言特性
-
u8
字元字面量 - 將 noexcept 作為型別系統的一部分
- 新的 求值順序 規則
- lambda 對 *this 的捕獲
- 名稱空間
- 簡化的巢狀名稱空間
- 宣告多個名稱的
using
-宣告 - 屬性名稱空間 無需重複
- 新 屬性:
-
[[fallthrough]]
-
[[maybe_unused]]
-
[[nodiscard]]
-
- __has_include
[編輯] 新標頭檔案
[編輯] 新庫特性
[編輯] 工具型別
[編輯] 記憶體管理
- 未初始化記憶體演算法
- weak_from_this
- std::pmr::memory_resource 和 std::polymorphic_allocator
- std::aligned_alloc
- 透明 std::owner_less
- 對 std::shared_ptr 的陣列支援
- 具有顯式對齊的 分配函式
[編輯] 編譯時程式設計
- std::byte
- std::conjunction/std::disjunction/std::negation
- 型別特性 變數模板 (
xxx_+v
) - std::is_swappable
- std::is_invocable
- std::is_aggregate
- std::has_unique_object_representations
[編輯] 演算法
[編輯] 迭代器和容器
- map/set extract 和 map/set merge
- map/unordered_map try_emplace 和 insert_or_assign
- 連續迭代器 (LegacyContiguousIterator)
- 非成員 std::size/std::empty/std::data
[編輯] 數值
- 數學特殊函式
- 3D std::hypot
[編輯] 其他
- 快取行介面
- std::launder
- std::uncaught_exceptions
- std::to_chars/std::from_chars
- std::atomic<T>::is_always_lock_free
- std::scoped_lock
- std::timespec_get
- 用於 std::chrono::duration 和 std::chrono::time_point 的舍入函式
[編輯] 缺陷報告
[編輯] 編譯器支援
[編輯] 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 迴圈 中不同的起始和結束型別 (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 (更新 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 (更新 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 (更新 2)* | 是 | 17.1.0 | 不適用 | 10.3 | |
邏輯運算子型別特性 (FTM)* | P0013R1 | 6.1 | 3.8 | 19.0 (更新 2)* | 是 | 17.1.0 | 不適用 | 10.3 | |
std::as_const (FTM)* | P0007R1 | 7.1 | 3.8 | 19.0 (更新 2)* | 是 | 17.1.0 | 不適用 | ||
用於 std::chrono::duration 和 std::chrono::time_point 的舍入函式 (FTM)* | P0092R1 | 7.1 | 3.8 | 19.0 (更新 2)* | 是 | 17.1.0 | 不適用 | ||
透明 std::owner_less (std::owner_less<void>) (FTM)* | P0074R0 | 7.1 | 3.8 | 19.0 (更新 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* (partial)* 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。
* - 將滑鼠懸停在標有星號 * 的單元格上可檢視額外的彈出式註釋。
DRnn - “DR”後的數字 nn 表示該缺陷報告(Defect Report)所適用的 C++ 修訂版本,例如 DR20 → C++20。
[編輯] 外部連結
1. | C++17 - 維基百科 |
2. | C++17 示例 |