1.对于拷贝复制构造,构造函数 ,拷贝构造操作符,当你为类中添加了新的元素时,要重新改变上面三个函数,确保每一个变量都能被赋值(还是记住 重载=的函数返回this指针)
2.下面考虑相关的继承关系
1).如果在拷贝构造函数或者默认构造函数中使用如下直接初始化,无法调用其构造函数,而是会弹出没有发现A::operator()函数。
class A{
private:
string name;
public:
A(const A& rhs){
name(rhs.name);
}
};
解决方法是用列表初始化
class A {
private:
std::string name;
public:
A(const A& rhs) : name(rhs.name) {}
};
2).当继承时,子类不仅有自己的成员 还有基类的成员 那么在调用子类的构造函数(多种)初始化类成员时,不要忘了通过子类的构造函数调用基类的构造函数从而去。
class A {
private:
std::string name;
public:
A(const A& rhs) : name(rhs.name) {}
};
class B :public A {
private:
int xx;
public:
B(const B& mm,const A& yy):A(yy),xx(mm.xx){
std::cout << "调用子类的构造函数时,同时要调用基类的构造函数 用列表初始化" << std::endl;
}
};
如果子类构造函数没调用基类的构造函数 那么编译器在生成子类变量时会调用基类的默认构造函数进行初始化。
3.)不同的构造函数不要混和调用。即不要让operator=函数调用copy构造函数(试图构造一个已经存在的对象,这是荒诞的),不要让copy构造函数调用operator=函数(都没初始化和创建,你怎末赋值。) 。相同类型的调用相同类型的。=符号只作用在已经初始化对象,copy构造函数是创建并且赋值类成员,是先创建后初始化再赋值。