標準庫容器中的自移動賦值
C 11 標準保證自移動賦值(物件在物件被賦值後為其自身賦值)對於像std::vector 這樣的標準函式庫容器來說是不可能的。
標準中的具體規定可以在 [res.on.arguments] 中找到,它指出綁定到右值引用的函數參數被視為對其綁定參數的唯一引用。這意味著實現可以假設參數與賦值目標引用的物件不同。
對於 std::vector,移動賦值運算子 (operator=) 定義為取得右值參考。因此,當使用 std::vector 參數呼叫 selfAssign() 時,標準允許實作假設該參數是對臨時物件的唯一參考。因此,自移動分配是不可能的,並且 std::vector 將處於無資源狀態(0 容量)。
但是,重要的是要注意,此行為僅保證標準庫容器。對於使用者定義類型,C 11 標準不提供任何有關自移動分配的保證。
以上是為什麼 C 11 中的標準庫容器不允許自移動分配?的詳細內容。更多資訊請關注PHP中文網其他相關文章!