类中的成员变量在对象构造时,是什么时候初始化的?
是在调用构造函数的过程中初始化的吗?不对!实际是在调用构造函数后,进入构造函数代码块内之前完成初始化的。成员变量默认使用其自身的(无参数)默认构造函数初始化,那么我们如何改变这一默认行为,让成员函数使用其他构造函数呢?方法是在构造函数定以后使用冒号开头并跟上初始化列别,详细语法请看下面的例子:
#include <iostream>
#include <string>
#include <vector>
#include <queue>
#include <stack>
#include <list>
#include <set>
#include <map>
using namespace std;
class Phone
{
private:
string no;
public:
Phone(const string &n = "no number") {
no = n;
cout << "Phone::ctor\n";
}
Phone(const Phone& cp) {
no = cp.no;
cout << "Phone::copy ctor\n";
}
const Phone& operator=(const Phone& rhs) {
no = rhs.no;
cout << "Phone::operator=\n";
return rhs;
}
};
class MyBook
{
private:
string name;
Phone phone1, phone2;
public:
MyBook(const string& n, const Phone& p) : phone2(p)
{
cout << "~~~~~~~~~~\n";
name = n;
phone1 = p;
phone2 = p;
}
};
int main()
{
Phone p1;
cout << "----------\n";
MyBook zym("abcd", p1);
return 0;
}
这段代码的输出为:
Phone::ctor
----------
Phone::ctor
Phone::copy ctor
~~~~~~~~~~
Phone::operator=
Phone::operator=
注意观察Phone类的构造函数的调用顺序。首先是我们的p1对象,然后是zym对象的,其中phone1调用默认构造函数,phone2调用拷贝构造函数。在zym的构造函数代码块中的=号是赋值运算,因为此时对象已经构造完成了。
最后,一定务必牢记,C++中的构造函数和赋值运算是完全不同的两类事物,虽然在对象构造和赋值时都(可以)出现等于符号(=),但这只是运算符的复用,其底层含义完全不同。