class A
{
public:
A(){ cout<<"A constructor\n";}
A(A& a){ cout<<"A copy constructor\n"; }
~A(){ cout<<"A destructor\n"; }
};
class B
{
public:
B(){ cout<<"B constructor\n";}
B(const B& a){ cout<<"B copy constructor\n"; }
~B(){ cout<<"B destructor\n"; }
};
上面两个类的拷贝构造函数都没有问题,B类的使用更加广泛,其中的原因还是和常量引用使用有关,常量引用可以接收引用和普通常量。
比如如下使用
template<typename T>
T makeT()
{
return T();
}
makeT<A>() //出现错误,return T() 需要拷贝对象, 是一个临时变量, A(A&) A构造函数需要左值引用
makeT<B>()
所以这种需要使用临时对象,需要拷贝的时候,const属性还是非常有用的。所以为了使用方便,构造函数参数还是需要使用const