早期C 11 草案中的隱式移動構造函數和賦值運算子
儘管C 中廣泛實現了預設複製構造函數和賦值運算符,但C 11標準的早期草案中缺少預設的移動構造函數和賦值運算符,這引起了人們的質疑
最初缺席的原因
移動操作的隱式生成一直是C 社群中持續爭論的主題。由於擔心保留依賴不可移動類型的代碼,C 11 標準的早期草案缺乏這些隱式功能。此外,使用賦值運算子的 std::move 與不可移動物件的行為使問題變得複雜。
現行規範
依據 11 月 N3225規範,如果類別沒有明確定義移動建構函數,它將在以下情況下隱式聲明為預設值條件:
類似的條件適用於移動賦值運算子的隱式聲明。這些變更與 N3203 和 N3201 中概述的原則一致,這些原則主張對隱式移動生成採取更嚴格的條件。
解決方法
在早期沒有隱式移動操作的情況下C 11 草案中,一種解決方法是手動實現移動賦值運算符和移動構造函數。為了避免在每個類別中實作這些運算符,可以採用巨集解決方案。 GManNickG 在 Stack Overflow 問題中的答案提供了一個適當的例子。
以上是為什麼早期 C 11 草案中沒有隱式移動建構函數和賦值運算子?的詳細內容。更多資訊請關注PHP中文網其他相關文章!