// 复制构造函数——浅复制and深复制(2).cpp : 定义控制台应用程序的入口点。
//本部分介绍1.浅复制的问题;2.如何进行深复制
#include "stdafx.h"
#include"conio.h"
#include"iostream"
using namespace std;
class Array {
public :
//声明复制构造函数
Array(const Array &a);
//普通构造函数
Array(int n) {
len = n;
p = new int[n];
for (int i = 0; i < n; i++) {
cout << "输入一个整数" << endl;
cin >> p[i];
}
}
//自定义析构函数
~Array()
{
delete []p;
}
//成员变量
int len;
int *p;
};
//默认复制构造函数(可不写,系统会自动生成),其作用是将a的数据成员经复制构造函数处理传递给新定义对象的成员。
/*Array(const Array &a) {
len = a.len;
p=a.p;
}*/
//使用复制构造函数
int main()
{
Array a1(4);
//这里我们给a1的p[4]赋值1、2、3、4;
Array a2(a1);//该语句的执行过程为先定义对象a2执行a2的复制构造函数,&a引用传递的变量为a1,经处理后得到由a1传过来的数据,得到了a2
//我们对a1的数组操作是其每个元素都加3
for (int i = 0; i < a1.len; i++)
a1.p[i]+=3;
//输出a1和a2数组的值
cout << "a1" << endl;
for (int i = 0; i < a1.len; i++) {
cout << a1.p[i]<< "\t";
}
cout << endl<< "a2" << endl;
for (int i = 0; i < a2.len; i++) {
cout << a2.p[i] << "\t";
}
_getch();
return 0;
}
//我们只对a1的数组p进行操作,其结果a1、a2的数组p都为4,5,6,7
//观察默认的赋值构造函数我们可以发现p=a.p;实际上为a2.p=a1.p;a1、a2的p都指向同一个内存单元所以才有上面的执行结果
//深复制就是要是a2的p指向另外的内存单元。
Array::Array(const Array &a) {
len = a.len;
//我们给新定义的对象重新申请内存
p = new int[len];
for (int i = 0; i < len; i++)
p[i] = a.p[i];
}
//这样我们就达到了深复制的目的
//本部分介绍1.浅复制的问题;2.如何进行深复制
#include "stdafx.h"
#include"conio.h"
#include"iostream"
using namespace std;
class Array {
public :
//声明复制构造函数
Array(const Array &a);
//普通构造函数
Array(int n) {
len = n;
p = new int[n];
for (int i = 0; i < n; i++) {
cout << "输入一个整数" << endl;
cin >> p[i];
}
}
//自定义析构函数
~Array()
{
delete []p;
}
//成员变量
int len;
int *p;
};
//默认复制构造函数(可不写,系统会自动生成),其作用是将a的数据成员经复制构造函数处理传递给新定义对象的成员。
/*Array(const Array &a) {
len = a.len;
p=a.p;
}*/
//使用复制构造函数
int main()
{
Array a1(4);
//这里我们给a1的p[4]赋值1、2、3、4;
Array a2(a1);//该语句的执行过程为先定义对象a2执行a2的复制构造函数,&a引用传递的变量为a1,经处理后得到由a1传过来的数据,得到了a2
//我们对a1的数组操作是其每个元素都加3
for (int i = 0; i < a1.len; i++)
a1.p[i]+=3;
//输出a1和a2数组的值
cout << "a1" << endl;
for (int i = 0; i < a1.len; i++) {
cout << a1.p[i]<< "\t";
}
cout << endl<< "a2" << endl;
for (int i = 0; i < a2.len; i++) {
cout << a2.p[i] << "\t";
}
_getch();
return 0;
}
//我们只对a1的数组p进行操作,其结果a1、a2的数组p都为4,5,6,7
//观察默认的赋值构造函数我们可以发现p=a.p;实际上为a2.p=a1.p;a1、a2的p都指向同一个内存单元所以才有上面的执行结果
//深复制就是要是a2的p指向另外的内存单元。
Array::Array(const Array &a) {
len = a.len;
//我们给新定义的对象重新申请内存
p = new int[len];
for (int i = 0; i < len; i++)
p[i] = a.p[i];
}
//这样我们就达到了深复制的目的