C++對象的淺復制和深復制詳解及簡單實例。本站提示廣大學習愛好者:(C++對象的淺復制和深復制詳解及簡單實例)文章只能為提供參考,不一定能成為您想要的結果。以下是C++對象的淺復制和深復制詳解及簡單實例正文
C++對象的淺復制和深復制詳解及簡單實例
淺復制:兩個對象復制完成後共享某些資源(內存),其中一個對象的銷毀會影響另一個對象
深復制:兩個對象復制完成後不會共享任何資源,其中一個對象的銷毀不會影響另一個對象
下面我們來看一段代碼,以便直觀的理解:
#include<iostream> #include<string.h> using namespace std; class Student { int no; char *pname; public: Student(); Student(int n,char* p); ~Student(); void display(); }; Student::Student(){} Student::Student(int n,char* p) { no=n; pname=new char[10]; strcpy(pname,p); } Student::~Student() { delete []pname; } void Student::display() { cout<<"學號:"<<no<<",姓名:"<<pname<<endl; } void main() { Student s(10,"xiaoming"),t; t=s; cout<<"s="; s.display(); cout<<"t="; t.display(); }
這段程序看上去是正確的,但是執行就會出錯,原因就是復制語句t=s,此語句執行的復制是淺復制,s將pname指針指向的地址賦給s的pname,它們就會指向相同的內存空間,當t被析構時,t.pname所指的內存空間就被釋放了,再執行s的析構函數就會出錯。
如果采用深復制就可以避免這個問題,下面我們用運算符重載函數實現深復制:
Student& Student::operator = (Student& s) { no=s.no; int len=strlen(s.pname); pname=new char[len+1]; strcpy(pname,s.pname); return *this; }
在執行t=s時,運算符重載函數內已為t分配內存空間。
對於上述運算符重載函數有兩點說明:
1.形參一定要是引用類型,否則執行t=s時,就要先將實參s復制到形參s,這個過程是淺復制,沒有為形參s分配內存空間,運行會出錯;
2.返回值一定要是引用類型,因為執行t=s相當於執行t.=(s),若返回值不是引用類型,那麼還要將函數的返回對象復制到t,又會出錯
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!