浅复制:两个对象复制完成后共享某些资源(内存),其中一个对象的销毁会影响另一个对象
深复制:两个对象复制完成后不会共享任何资源,其中一个对象的销毁不会影响另一个对象
下面我们来看一段代码,以便直观的理解:
?
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,又会出错
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
相关文章
猜你喜欢
- 64M VPS建站:如何选择最适合的网站建设平台? 2025-06-10
- ASP.NET本地开发时常见的配置错误及解决方法? 2025-06-10
- ASP.NET自助建站系统的数据库备份与恢复操作指南 2025-06-10
- 个人网站服务器域名解析设置指南:从购买到绑定全流程 2025-06-10
- 个人网站搭建:如何挑选具有弹性扩展能力的服务器? 2025-06-10
TA的动态
- 2025-07-10 怎样使用阿里云的安全工具进行服务器漏洞扫描和修复?
- 2025-07-10 怎样使用命令行工具优化Linux云服务器的Ping性能?
- 2025-07-10 怎样使用Xshell连接华为云服务器,实现高效远程管理?
- 2025-07-10 怎样利用云服务器D盘搭建稳定、高效的网站托管环境?
- 2025-07-10 怎样使用阿里云的安全组功能来增强服务器防火墙的安全性?
快网idc优惠网
QQ交流群
您的支持,是我们最大的动力!
热门文章
-
2025-05-25 43
-
2025-05-29 55
-
2025-05-27 64
-
2025-05-25 93
-
2025-06-04 24
热门评论