自定义复制构造函数

小编在编写构造函数之时,想到以前遇到的一个关于构造函数复制的问题,因为同一个类的对象在内存中的有完全相同的结构,如果作为一个整体进行复制或者拷贝是完全可行的,这个拷贝过程是只需要拷贝数据成员,而函数成员是公用的。在建立对象时可用同一类的另一个对象初始化该对象,即复制初始化构造函数。但是当希望从另外一个同类对象处得到部分属性值时,或类的成员数据使用new操作符动态申请存储空间存储数据时,必须在类中自定义一个完成复制功能的构造函数。简单代码如下:#include
#include
using namespace std;
class student
{
char * name;
int age;
public:
/student(student &p)
{
if (p.name)
{
age = p.age;
name = new char[strlen(p.name) + 1];
strcpy(name, p.name);
}
else name = 0;
}
/

student(const char * tname, int a)
{
	if (tname)
	{
		age = a;
		name = new char[strlen(tname) + 1];
		strcpy(name, tname);
	}
	else name = 0;
}
~student()
{
	cout << name << "age is" << age << "years old." << endl;
	if (name) delete name;
}

};
int main()
{
student st1(“LIMING”, 20);
student st2(st1);
system(“pause”);
return 0;
}
但是在实际操作中会出现,如下中断自定义复制构造函数_第1张图片
此中断是由于
~student()
{
cout << name << “age is” << age << “years old.” << endl;
if (name) delete name;
}
中第二次执行析构函数中的delete name;语句时出错;其时对象st2释放时,调用析构函数释放掉动态空间,对象st1释放时,调用析构函数又想释放已被对象st2释放掉的动态对象空间因此出错。纠正为
student(student &p)
{
if (p.name)
{
age = p.age;
name = new char[strlen(p.name) + 1];
strcpy(name, p.name);
}
else name = 0;
}
结果即运行正确。
在这里插入图片描述

你可能感兴趣的:(c++)