#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
using namespace std;
class MyName
{
public:
MyName(const char* myName)
{
m_len = strlen(myName);
p = (char*)malloc(m_len + 1);//\0
strcpy(p,myName);
}
~MyName()
{
if (p != NULL)
{
free(p);
p = NULL;
m_len = 0;
}
}
private:
char* p;
int m_len;
};
int main()
{
MyName name1("aa");
MyName name2 = name1;
system("pause");
return 0;
}
执行之后发现编译可以通过,执行也正常,但是结束时会出现问题
原因:
C++编译器只支持浅拷贝,name2初始化是通过name1的赋值进行的,此时编译器会调用类的copy构造函数,而我们并没有重写copy构造函数,而是调用的默认的copy构造函数,由于C++编译器只支持浅拷贝,造成了只复制了指针变量,而指针变量所指向的内存空间并没有复制,即 name1和name2指向了同一值,当程序进行析构时,首先析构name2,此时释放内存空间,当析构name1时,由于内存空间已经被释放,此时编译器报错
解决方法:
在MyName类中重写copy构造函数:
MyName(const MyName& myName)
{
m_len = myName.m_len;
p = (char*)malloc(m_len + 1);
strcpy(p, myName.p);
}