转自:http://handong-4.spaces.live.com/blog/cns!231105867A4D70FA!290.entry?wa=wsignin1.0&sa=905277578
C++类的构造函数、拷贝构造函数、‘=’运算符调用问题
C++类的构造函数调用问题
在什么情况下编译器会自动调用类的默认构造函数?在什么情况下会调用类的拷贝构造函数?如果一个类没有重载=操作符,那么用=进行复制运算的时候会调用哪个构造函数?会出现什么错误?
问题补充:我大概罗列了一下两者的用处,有不对或者不全的地方请指正.
默认构造函数:
声明类的对象的时候
声明类的数组的时候(每个元素会单独调用一次)
调用等号运算符的时候(等号左边的变量会先调用一次)
拷贝构造函数:
类的对象作为参数传递给函数的时候
类的对象作为返还值的时候
最佳答案
默认构造函数:
声明类的对象的时候
声明类的数组的时候(每个元素会单独调用一次)
调用等号运算符的时候(等号左边的变量会先调用一次)================================================
最后一句是不对的。上两句是对的
如果等号左边的变量还没有实例化的话,只会调用拷贝构造函数,不会调用默认构造函数的,也不会调用=运算符。 即
CTest aa; //调用默认构造函数
CTest bb = aa; //只会调用拷贝构造函数,不会调用默认构造函数的,也不会调用=运算符。就相当于 CTest bb(aa);
但是如果 aa = bb; //这只会调用=运算符,因为aa已经实例化了
要弄明白拷贝构造函数的意思,就是拷贝一个对象来构造另外一个对象,重点是“构造”这个词,如果说aa已经被构造了(实例化),那下面还要构造什么呢,也就不会再调用拷贝构造函数了,能进行的操作只能是重新赋值而已,就是=运算符。但是像CTest bb = aa; 因为bb还没有构造,那只能调用拷贝构造函数了
拷贝构造函数:
类的对象作为参数传递给函数的时候
类的对象作为返还值的时候
====================================
第一句是对的,第二句是不对的。比如
假如有个函数是这样(返回类型不管是不是引用类型,下面的结果都是一样):
CTest getTest() { return m_myTest; }
那么,
CTest aa; //实例化aa,调用默认构造函数
aa = getTest(); //只会调用 = 运算符,不会调用任何构造函数,因为aa已经实例化了。
CTest bb = getTest(); //此时返回值后只会调用拷贝构造函数,不会调用其他的函数,包括=运算符也不会被调用。
所以不论是赋值还是调用,只要看赋值左边的变量是否已经被实例化了,如果实例化了,只会调用=运算符, 如果没有,只会调用拷贝构造函数。类的对象作为参数传递给函数的时候(不是引用类型),就是把一个对象给一个没有实例化的变量赋值,所以这时只会触发拷贝构造函数,而不是其它函数。
这些都是硬道理,没什么再深入讲的,如果实在不明白,就死记着吧。