首頁 >後端開發 >C++ >「if (this != &rhs)」檢查是否應該包含在移動賦值運算子中?

「if (this != &rhs)」檢查是否應該包含在移動賦值運算子中?

Patricia Arquette
Patricia Arquette原創
2024-11-29 11:55:11730瀏覽

Should the `if (this != &rhs)` Check Be Included in a Move Assignment Operator?

移動賦值運算子和if (this != &rhs)

在類別的賦值運算子中,這是常見的做法檢查正在分配的物件是否是呼叫物件以避免潛在的錯誤。這是使用條件 if (this != &rhs) 完成的。

但是,在移動賦值運算子的上下文中,特別是當右側 (RHS) 是右值引用時(例如Class&&),有一個問題是這個檢查是否必要。

有些人認為不需要檢查,因為右值引用總是引用一個唯一的、臨時的對象,不能被在別處別名。在這種情況下,這個 != &rhs 總是為真。

其他人認為,儘管標準沒有嚴格要求,但檢查作為防禦措施仍然是可取的。他們斷言,如果客戶端程式碼錯誤地傳遞自引用,它可以提供額外的保證並防止潛在的錯誤或未定義的行為。

普遍的共識似乎是,在 move 的上下文中,檢查並不是嚴格必要的分配,但它也沒有害處。如果行動分配是使用流行的複製和交換習慣用法實現的,則通常的做法是包含檢查。但是,如果在沒有 Copy 和 Swap 的情況下實現移動分配,則可能會省略檢查。

最終,是否包含檢查的決定取決於個人喜好和設計考慮。

以上是「if (this != &rhs)」檢查是否應該包含在移動賦值運算子中?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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