虚位以待(AD)
虚位以待(AD)
首页 > 软件编程 > C/C++编程 > C++对象的浅复制和深复制详解及简单实例

C++对象的浅复制和深复制详解及简单实例
类别: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,又会出错

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

相关热词搜索: C++ 浅复制和深复制 C++ 浅复制和深复制详