gpt4 book ai didi

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

转载 作者:qq735679552 更新时间:2022-09-28 22:32:09 24 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章C++对象的浅复制和深复制详解及简单实例由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

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

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

最后此篇关于C++对象的浅复制和深复制详解及简单实例的文章就讲到这里了,如果你想了解更多关于C++对象的浅复制和深复制详解及简单实例的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com