template <class T> class BigNumber{
long n;
public:
BigNumber (T i):n(i) { }
BigNumber operator+(BigNumber b) {
return BigNumber(n+b.n);
}
};
有如上的类模板定义,已知b1、b2是BigNumber的两个对象,则下列表达式中错误的是(D)
A、3+3 B、b1+3 C、b1+b2 D、3+b1
分析:
3+3就是正常的3+3;
b1+3是BigNumber(b1)+BigNumber(3)
b1+b2是BigNumber(b1)+BigNumber(b2)
3+b1 常数3无法匹配到此模板中的+重载函数,编译器无法识别。 D选项中+前面的操作数必须是一个BigNumber的对象,3不是此对象,所以错了。
这里有个隐式类类型转换的过程,b1+3。b1+BigNumber(3),再调用重载的+运算。而3+b1错误,是因为3+就是正常的int+,不会触发隐式类型转换。
————————————————————————————————————————
此题考查的是C++运算符重载,+号被重载后相当于该类的一个成员函数了,出现该类对象(b1+)这种就是调用重载函数,+号后面的3或b2就是参数,如果是3的话就会执行类型转化,将3变为BigNumber类型传给形参。D中的错误是因为+号左右两边的类型不匹配。
——————————————————————————————————————————
运算符重载调用形式:
b1.operator+(参数) 简写成b1+参数
B会进行类型转换
D错误,3是int类型,无法调用b1的加法操作。
———————————————————————————————————————————
operator+被定义为一个成员函数,因此this指针指向的是左操作数,因此B和C是正确的。因为此处把+视为了其左操作数的成员函数,而右操作数为+的参数。而D错误是因为此时3是一个整形变量,此时的+号运算默认为基本加号运算而不是重载之后的加号运算。如果把重载+换为非成员函数,此时D也是正确的。
——————————————————————————————————————————
一般建议+这样的重载运算符不要定义为成员函数。
定义为成员函数的双目操作符重载,左操作数必须是类的对象。定义为友元函数可以破解这一限制。