* 如果没有定义构造函数,复制构造函数,赋值构造函数,析构函数,编译器帮你定义,并把这些函数是为public。如果某些数据成员无法进行赋值,那么就不会定义赋值构造函数。
这些函数包括:默认构造函数,复制构造函数,赋值构造函数,以及析构函数。这些函数都属于public部分。
在有些情况下,赋值构造函数时没有意义的,此时编译器就会拒绝构造一个这样的函数,举一个例子:
template <typename T>
class Test
{
public:
Test(const T val,string& str):value(val),name(str){}
void print(){cout<<value<<name<<endl;}
private:
const T value;
string& name;
};
void main()
{
string str = "2";
Test<int> t1(2,str); //合法
Test<int> t2(t1); //合法
Test<int> t3(3,str); //合法
t3 = t1; //非法
}
为什么合法?因为对引用name成员是初始化操作,const成员同样是初始化;
为什么非法?因为试图去改变引用所指向的变量(这一操作本来就是非法的);试图改变const成员变量的值。
以上非法情况编译器会拒绝构造赋值构造函数。
还有一种情况,就是如果基类的赋值构造函数为private,那么编译器也不会为派生类构造一个赋值构造函数,因为通常情况下,总是希望派生类调用基类的赋值构造函数来对基类的数据成员进行赋值,而此时基类的赋值构造函数却无法被继承。