您好,登錄后才能下訂單哦!
這篇文章主要介紹“C++為什么要保持默認操作的一貫性”,在日常操作中,相信很多人在C++為什么要保持默認操作的一貫性問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”C++為什么要保持默認操作的一貫性”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
C.22: 保持默認操作的一貫性
默認操作從概念上講是配合嚴密的一整套處理。它們的語義是相互關聯的。如果拷貝/移動構造和拷貝/移動賦值做的是邏輯上不同的事情,用戶會感到詫異;如果構造函數和析構函數沒有為資源管理提供一致的想法,用戶會感到詫異;如果拷貝和移動操作沒有對應構造函數和析構函數的動作,用戶會感到詫異。
class Silly { // BAD: Inconsistent copy operations
class Impl {
// ...
};
shared_ptr<Impl> p;
public:
Silly(const Silly& a) : p{a.p} { *p = *a.p; } // deep copy
Silly& operator=(const Silly& a) { p = a.p; } // shallow copy
// ...
};
這些操作(拷貝構造和賦值)關于拷貝的語義不同(風別是深拷貝和淺拷貝)。這會導致困惑和錯誤。
<ul class=">
(復雜) 拷貝/移動構造函數和對應的拷貝/移動賦值運算符應該以同樣的的解引用級別寫入同樣的成員變量。
(復雜)在拷貝/移動構造函數中寫入的任何成員變量也應該被其他的構造函數初始化。
(復雜)如果拷貝/移動構造函數對成員變量進行深拷貝,那么析構函數應該修改該成員變量。
(復雜)如果析構函數修改某個成員變量,那么這個成員變量應該在拷貝/移動構造函數或者賦值運算符中被寫入。
到此,關于“C++為什么要保持默認操作的一貫性”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。