C++对象的浅复制和深复制详解及简单实例

2025-05-27 0 88

C++对象的浅复制深复制详解及简单实例

浅复制:两个对象复制完成后共享某些资源(内存),其中一个对象的销毁会影响另一个对象

深复制:两个对象复制完成后不会共享任何资源,其中一个对象的销毁不会影响另一个对象

下面我们来看一段代码,以便直观的理解:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42
#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的析构函数就会出错。

如果采用深复制就可以避免这个问题,下面我们用运算符重载函数实现深复制

?

1

2

3

4

5

6

7

8
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,又会出错

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

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 C++对象的浅复制和深复制详解及简单实例 https://www.kuaiidc.com/73489.html

相关文章

发表评论
暂无评论