潜复制和深复制以及复制构造函数_努力的小带土的博客-CSDN博客续潜复制及复制构造函数。
关于自建类的赋值问题假设存在类Tperson,如下所示:(主要用到的成员变量为_name 和address)
class Tperson
{
private:
char* _name ;
char* address ;
// len1 和 len2分别存储_name和address的字符长度
int len1 ;
int len2 ;
.........
public:
.........
}
我们肯定希望该类能进行赋值操作,即假设存在person1 和 person2 均是该类类型,将person2赋值为person1 即 person2 = person1 。若我们没有在类中申明赋值函数,此时编译器会使用自动赋值函数,该函数其实就是上述连接中提到的潜复制。实际的内部实现如下述代码所示:
person2._name = person1._name ; //地址复制
person2.address = person1.address ; //地址复制
而我们不想看到这样的赋值,原因在于person1和 person2 共用同一片数据地址,当我们误删了一个对象的时候,另一个对象的信息也被删除。因此便涉及到赋值函数的申明,具体赋值函数的申明如下所示:
Tperson& Tperson::operator=(const Tperson& p1)
{if(this == &p1) // 若是对自己赋值,直接退出{return *this ;}// 若不是对自己赋值,则清空内存delete [] _name ;delete [] address;// 分配内存len1 = p1.len1 ;len2 = p1.len2 ;_name = new char[len1+1];address= new char[len2+1];// 赋值strcpy(_name ,p1._name);strcpy(address,p1.address);return *this
}
下面对该代码进行详细解释,首先是返回值,返回值确保了可以连续赋值的操作即 p1 = p2 = p3在函数形式来看是这样的p1.oeprator=(p2.operator=(p3));,其次在函数删除现有内存空间的时候,先检查一下赋值对象是不是自己,若是自己则无需进行下面操作直接返回。若不是自己,则清空内存中现有的字符串,然后为新字符串分配内存,最终将字符串的字符信息复制到char指针中,完成类的赋值函数。值得注意的是赋值函数只能是成员函数。