拷贝构造函数
class B{
int b;
public:
B(int b1):b(b1){}
B(const B &in):b(in.b){}
};
1.为什么要用引用?
如果不使用引用,就会重复调用拷贝构造函数,无法脱离递归循环。
2.为什么要用const?
如果在函数中不会改变引用类型参数的值,加不加const的效果是一样的。而且不加const,编译器也不会报错。但是为了整个程序的安全,还是加上const,防止对引用类型参数值的意外修改。
拷贝构造函数在类中的继承
class A{
int a;
public:
A(int a1):a(a1){}
A(const A &in):a(in.a){}
int getA(){return a;}
};
class B:public A{
int b;
public:
B(int b1,int a1):b(b1),A(a1){}
B(const B &in):b(in.b),A(in){}
};
通过调用基类的拷贝构造函数来完成基类的拷贝构造函数
Q:为什么const对象的属性改变了?
A:const仅保证指针不发生改变,修改对象的属性不会改变对象的指针,所以是被允许的。
class A{
int a;
public:
A(int a1):a(a1){}
A(const A &in):a(in.a){}
int getA()const {return a;}
};
class B: public A{
int b;
public:
B(int b1,int a1):A(a1),b(b1){}
B(const B &in):A(in.getA()),b(in.b){}
};
通过直接把基类的成员变量赋值给子类完成拷贝构造函数
Q1:为什么要在getA函数后加const?
A1:const对象仅能够调用const成员函数
Q2:为什么const对象仅能够调用const成员函数?
A2:http://www.cnblogs.com/cplinux/articles/5553716.html添加链接描述