您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關C++中怎么實現對象復制,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
C++對象復制代碼示例:
class Table{ Name * p; size_t sz; publish: Table(size_t s = 15){p = new Name[ssz=s];} ~Table(){delete[]p ;} ...... } void h() { Table t1; Table t2 = t1; Table t3; t3 = t2; }
在h()結束時,默認構造函數調用了2次,而析構函數被調用了3次,為何?
Table t1; 調用1次默認構造函數
Table t2 = t1;默認的對象的賦值操作,按成員賦值,其中關于指針p,僅僅是將t1.p賦值給t2.p,即t2.p = t1.p,并無內存分配。對象t1和t2的p指針均指向同一塊內存。
Table t3; 調用1次默認構造函數
t3 = t2; 原t3.p指針被t2.p覆蓋,此時t3.p同樣指向對象t1和t2的p指針的同一塊內存。注意:t3原分配給p的內存由于沒有指針指向,無法利用,造成存儲浪費。
h()結束,對象t1,t2,t3的析構函數調用,此時對t1,t2,t3的指針p所指的同一塊存儲進行了三次刪除,非常危險,導致的結果是無發預料的,很可能災難性的。
因此明確定義類的復制構造函數(拷貝構造函數)和賦值預算可避免這樣的錯誤。
代碼
Table::Table (const Table &t) { p = new Name[sz=t.sz]; for(int i=0;i<sz;i++) p[i]=t.p[i]; } Table & Table::operator=(const Table &t) { if(this!=&t){ delete []p; p = new Name[sz=t.sz]; for(int i=0;i<sz;i++) p[i]=t.p[i]; } return *this; }
看完上述內容,你們對C++中怎么實現對象復制有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。