首頁 >後端開發 >C++ >為什麼早期 C 11 草案中沒有隱式移動建構函數和賦值運算子?

為什麼早期 C 11 草案中沒有隱式移動建構函數和賦值運算子?

Linda Hamilton
Linda Hamilton原創
2024-12-06 10:18:13546瀏覽

Why Were Implicit Move Constructors and Assignment Operators Absent in Early C  11 Drafts?

早期C 11 草案中的隱式移動構造函數和賦值運算子

儘管C 中廣泛實現了預設複製構造函數和賦值運算符,但C 11標準的早期草案中缺少預設的移動構造函數和賦值運算符,這引起了人們的質疑

最初缺席的原因

移動操作的隱式生成一直是C 社群中持續爭論的主題。由於擔心保留依賴不可移動類型的代碼,C 11 標準的早期草案缺乏這些隱式功能。此外,使用賦值運算子的 std::move 與不可移動物件的行為使問題變得複雜。

現行規範

依據 11 月 N3225規範,如果類別沒有明確定義移動建構函數,它將在以下情況下隱式聲明為預設值條件:

  • 沒有用戶聲明的複製構造函數
  • 沒有用戶聲明的複製賦值運算子
  • 沒有使用者宣告的移動賦值運算子
  • 否使用者宣告的析構函式
  • 沒有隱式刪除移動建構子

類似的條件適用於移動賦值運算子的隱式聲明。這些變更與 N3203 和 N3201 中概述的原則一致,這些原則主張對隱式移動生成採取更嚴格的條件。

解決方法

在早期沒有隱式移動操作的情況下C 11 草案中,一種解決方法是手動實現移動賦值運算符和移動構造函數。為了避免在每個類別中實作這些運算符,可以採用巨集解決方案。 GManNickG 在 Stack Overflow 問題中的答案提供了一個適當的例子。

以上是為什麼早期 C 11 草案中沒有隱式移動建構函數和賦值運算子?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn