C++標準委員會最近在夏威夷的科納召開了一次會議,大家可能關心最新的進展,但是按照以往的情況,某些檔案需要很久才會公開。會議進行的時候, 大家都在忙著修訂自己的檔案,會議之後,大會會收集改好的檔案,在幾周之後釋出。但是這一次,委員會修改了他們的系統,所以得到早些版本的檔案非常簡單, 這些郵件就是公開的。
我從官方收集與組織了這些資訊,沒有任何我個人的主觀評論。如果你想知道這次會議的主要內容,請閱讀下面的內容(我已經知道了絕大多數關於C++17 庫的內容,但是要將其全部寫出來還是需要一定的時間)
C++17 核心庫檔案
- P0001R1 棄用 register 關鍵字
- P0002R1 bool 型別不再支援++運算子
- P0012R1 異常成為型別系統的一部分,第五版
- P0061R1 支援__has_include
- P0134R0 引入非靜態成員變數的拷貝建構函式//not sure
- P0136R1 重寫繼承構造器(core issue 1941 et al)
- P0160R0 刪除一元運算子的預設值//Wording for removing defaults for unary folds
C++17 庫相關檔案
- P0004R1 棄用過時的 iostreams 的別名
- P0006R0 採用基於標準庫規範的型別特徵變數模板
- P0092R1 優化
- P0007R1 Constant View:一個::as_const 的輔助函式模板
- P0156R0 可變的 lock_guard (Rev. 3)
- P0074R0 使 std::owner_less 更加靈活
- P0013R1 邏輯運算子型別特徵 (revision 1)
庫基本規範第二版檔案
- N4531 替換 std::rand,版本三
- P0013R1 邏輯運算子型別特徵 (revision 1)[C++17 投票通過]
- 這些檔案將會應用於 N4529 草案,然後進行擬議草案技術規範的投票。
併發規範
- P0159R0 將會作為併發技術規範釋出,屆時可能稍作改動。
並行規範 v2
- N4505 草案和 P0155R0 的”Task Block R5”負責這項工作。
網路規範
- P0112R1 草案負責這想工作。
範圍規範
- P0021R0 草案負責這項工作。
核心主題
- 1274. 常見的非終結符表示式和內嵌初始化列表
- 1391. 非推導模板引數到引數型別的轉化
- 1722. lambda 函式指標轉換函式應該不例外嗎?
- 1847. 部分排序時宣告一致性
- 1863. 丟擲物件的型別應該支援 std::current_exception ()
- 1949. ”sequenced after”代替”sequenced before”
- 1975. 允許宣告異常型別
- 1981. 隱式和顯式的上下文轉換
- 1990. decl-specifier-seq 造成的歧義
- 2000. #include 之外的標頭檔案名稱
- 2004. 常亮表示式中有可變成員的變數
- 2006. Cv-qualified 的 void 型別
- 2015. 虛擬函式的 odr-use
- 2016. 型別轉換函式的描述中可能存在的歧義
- 2019. 儲存時間描述中成員引用的省略
- 2024. 依賴型別和未解包的引數包
- 2026. Zero-initialization 和 constexpr
- 2027. 指定多個 alignas 的需求不明
- 2031. &&的不相容
- 2052. 模板引數推導 vs 過載操作符
- 2075. 傳遞短初始化列表給陣列引用引數
- 2101. 對型別和值的依賴的錯誤說明
- 2120. 陣列作為標準佈局類的第一個非靜態成員變數
庫主題
- 1169. num_get 不能和 strto*完全相容
- 2072. 緩衝區容量定義不明確
- 2101. 一些型別轉換可能產生非預期的型別
- 2111. 處理異常時可能呼叫那些已經刪除的控制程式碼?
- 2119. 擴充套件 int 型別缺少雜湊函式
- 2127. 帶 raw_storage_iterator 的 Move-construction
- 2133. 過載逗號迭代器
- 2156. 無序容器的 reserve (n)儲存的是n-1 個元素
- 2218. 容器如何使用 allocator_traits::construct ()不夠明確
- 2219. INVOKE-ing 一個帶有 reference_wrapper 的指標作為物件表示式
- 2224. 不活躍物件的狀態問題
- 2234. assert ()應該允許在常亮表示式中使用
- 2244. 關於 basic_istream::seekg 的 issue
- 2250. Library Issue 2207 中的 Follow-up
- 2259. 17.6.5.5 規則中有關成員函式的問題
- 2273. regex_match 的歧義
- 2336. is_trivially_constructible/is_trivially_assignable 結果永遠是 false
- 2353. std::next 限制過度
- 2367. pair 和 tuple 無引數時不相容 is_constructible
- 2380. 應該提供 long ::abs (long) 和 long long ::abs (long long)嗎?
- 2384. 分配器的解除函式需要更好的規範
- 2385. function::assign 分配器引數無意義
- 2435. reference_wrapper::operator ()的標記應該是被刪除
- 2447. 分配器和 Volatile-qualified 值型別
- 2462. std::ios_base::failure 被過度規範
- 2466. allocator_traits::max_size ()預設表現是錯誤的
- 2469. map 的[]操作符和 unordered_map 規則錯誤
- 2473. basic_filebuf 對C檔案的相容
- 2476. scoped_allocator_adaptor 是不可分配的
- 2477. std::vector::erase ()和 std::deque::erase ()的不一致
- 2483. throw_with_nested ()應該使用 is_final
- 2484. rethrow_if_nested ()是不可實現的
- 2485. 常量 tuple&&應該過載 get()
- 2486. mem_fn ()應該提供向前相容
- 2487. bind ()不應該是 cv-overloaded, 而應該是 const-overloaded
- 2489. mem_fn ()應該是 noexcept 的
- 2492. 明確 comp 的需求
- 2495. 沒有類似異常安全元素的東西
Library Fundamentals TS v2 Issues
- 2494. [fund.ts.v2] ostream_joiner 應該是 noexcept 的
- 2500. [fund.ts.v2] fundts.memory.smartptr.shared.obs/6 應該適用於 cv-unqualified void
- 2515. [fund.ts.v2]observer_ptr 的確定操作符不能匹配任何簡介
- 2517. [fund.ts.v2] 兩個 propagate_const assignment 操作符返回不正確的型別
- 2526. [fund.ts]experimental::function::swap 條件不正確
更多資訊
以上只是投票通過的部分記錄。每次的會議都會涉及很多工作,不會全都反映在檔案上,比如,有關 modules 的熱烈討論檔案中就沒有。雖然我幾乎花了所有的時間在庫工作組中,但是還是不能跟進所有的內容。最終版檔案我會在 Reddit 分享各個模組的進展。
本文作者可以回答大多數有關庫的問題,但是可能回覆略有延遲。可以確定的是,庫的可用性提高了。看起來一切都像小貓一樣溫順可愛,但是如果你去 看一眼過載集合,就會發現這些模稜兩可的東西簡直是災難。LWG2451 是作為標準庫定義的一個極好的例子,optional opt_str = “meow”;現在還未實現。對於基本規範沒有什麼問題,但是 optional 的 ship-stopper 不符合國際標準。在這次會議上,LWG 意識到一些 issue 影響到了 variant,問題會牽扯到基本規範。當然了,會議會解決這些問題,你不必經歷這些痛苦。