copy构造函数和assign构造函数的调用很有趣,下面有个好玩的例子
#include <iostream>
#include <stdlib.h>
using namespace std;
class CAT
{
public:
CAT(int a):num(a){ cout << "constructor...." << endl; }
CAT(const CAT& rsh){num=rsh.num;cout<<"copy construtor called \n";}
CAT& operator =(const CAT& rsh)
{
cout << "assigning constructor called" << endl;
num = rsh.num;
return *this;
}
~CAT(){}
private:
int num;
};
int main(int argc, char *argv[])
{
CAT a(10);
CAT b(20);
cout<<"CAT d=a\n";
CAT d=a; //<-----这里会调用,视为CAT d(a)
d = a;
system("PAUSE");
return 0;
}
实际运行发现
CAT d=a;编译器做处理时,似乎没有变成
CAT d;
d = a;
而是直接做为
CAT d(a)进行处理。
只有真正 d=a,才执行assign构造函数,我想这应该是编译器出于效率考虑的结果,又或者是C++语法本身的规定,这就不知道了。