Big Three三个特殊函数 (拷贝构造函数、拷贝赋值函数、析构函数)
1 拷贝构造函数
定义:如果一个构造函数的第一个参数是自身类型的引用,且任何额外的参数都有默认值,则此构造函数是拷贝构造函数。
相关知识点:
如果拷贝构造函数中不含指针的话,那么编译器会自动生成拷贝构造函数,一位一位得进行赋值操作,此时采用系统的默认的拷贝构造函数没有问题。
但如果拷贝构造函数中有指针数据,如果还是采用默认但构造函数,则拷贝过来则指针会与原指针指向同一个地方,即所谓浅拷贝。
这时就要通过自己写但拷贝构造函数来进行深拷贝。
inline
String::String(const String& str)
{
m_data = new char[ strlen (str.m_data) + 1];
strcpy(m_data, str.m_data);
}
这个拷贝构造函数中,先给m_data用new来创建一个空间,然后再将指针数据复制过来。
2 拷贝赋值函数
定义:拷贝赋值函数即对“=”运算符的重载
有一点特别注意,即一定要在operator= 中检查是否self assignment
inline
String& String::operator=(const String& str)
{
if (this == &str)
return *this;
delete[] m_data;
m_data = new char[strlen(str.m_data) + 1];
strcpy(m_data, str.m_data);
return *this;
}
如果不进行检测,则函数在运行时会将this自身的指针内存先删除,然后分配一块和新的数据相同大小的内存,再将新的拷贝到旧的上面,可是因为是自身,所以这时会出错,因为新的数据内存已经被删除了。
3 析构函数
定义:析构函数执行与构造函数相反的操作:构造函数初始化对象的非static数据成员,还可能做一些其他工作;析构函数释放对象使用的资源,并销毁对象的非static数据成员。
析构函数是类的一个成员函数,名字由波浪号接类名构成,它没有返回值,也不接受参数:
inline
String::~String()
{
delete[] m_data;
}