当只有一个成员变量时,有一些不太注意的缺省转换发生,这是编译器造成的。
![]()
#include<iostream>#include<cstdlib>using namespacestd;classclassA {intx;public: classA(intx) {this->x = x; } classA(char*x) {this->x = atoi(x); }intgetX() {returnx; } };intmain ( ) { classA ca(5); //正常调用构造函数 cout << "x = " << ca.getX() << endl; ca = 100; //缺省调用classA(100) cout << "x = " << ca.getX() << endl; ca = "255"; //缺省调用classA("255") cout << "x = " << ca.getX() << endl;return0; }
默认转换带来一定的方便,同时也造成不必要的失误,为了防止失误,可以在构造函数前加“explicit”。
![]()
#include<iostream>#include<cstdlib>using namespacestd;classclassA {intx;public:explicitclassA(intx) {this->x = x; }explicitclassA(char*x) {this->x = atoi(x); }intgetX() {returnx; } };intmain ( ) { classA ca(5); //正常调用构造函数 cout << "x = " << ca.getX() << endl; ca = 100; //编译出错 cout << "x = " << ca.getX() << endl; ca = "255"; //编译出错 cout << "x = " << ca.getX() << endl;return0; }
当一个类的成员变量的类型是另一个类时,称之为“合成(composite)”。构造函数在对这个变量赋值时,不能在函数体里面赋值,只能用“第06章”中的方法2,即创建时赋值。
![]()
#include<iostream>using namespacestd;classclassB {intx;public: classB(intx) {this->x = x; }intgetB() {returnx; } };classclassA { classB xb;public: //classA(classB b) { xb = b; } //编译出错 classA(classB b) : xb(b) { } //只能用这种方法intsetX() {returnxb.getB(); } };intmain ( ) { classB cb(5); //先定义一个classB的实例 classA ca(cb); //然后用这个实例创建classA的实例 cout << "x = " << ca.getX() << endl;return0; }