当同时有copy constructor和operator= overload时,各自的调用时机:
class T
{
public:
T(){} //default constructor
T(int i){}
T(T const &t){} //copy constructor
T& operator=(T const &t){} //operator =
~T(); //destructor constructor prefer to not be inline.
};
void test(T t){}
T t1; //default constructor.
T t10 = T(); //显示调用default constructor.
//如果没有定义任何constructor, compiler不会做任何事情。成员数据将不会被初始化
//如果只没有定义default constructor, compiler报错:没有合适的默认构造函数
T t2 = t1; //copy constructor. 因为这句话是创建一个对象,所以不调用operator=。
T t2(t1); //copy constructor,推荐
T tt = T(t1); //显示调用copy constructor.
//如果没有定义copy constructor(甚至没有定义任何constructor), compiler会使用默认的bitewise copy
T t3 = 3; //调用T(int)
T t4(4); //调用T(int), 推荐
T t5 = T(5); //调用T(int)
T t[6]; //调用6次T()
T *t7 = new T; //调用1次T()
T *t8 = new T(); //调用1次T(),与上面一句同
T *t9 = new T[9]; //调用9次T()
t1 = t2; //operator=.此时t1和t2都创建好了。如果没有重载operator=,则与copy constructor一样,compiler会使用默认的bitewise copy(注意不会去调用copy constructor)。
t1 = 1; //先调用T(int),再调用operator=
test(2); //调用T(int),将2转换为T(这就是所谓的类型转换)
test(t1); //调用copy constructor,创建参数