Effective C++ 条款24:若所有的参数界需要类型转换,请为此采用non-member
假设我们写了一个有理数类,并支持其中的*重载
class Rational {
public:
Rational(int numerator = 0, int denominator = 1);
int numerator() const;
int denominator() const;
const Rational operator*(const Rational& rhs) const;
private:
};
下面我们使用这个类
int main() {
Rational oneEight(1, 0); // ok
Rational onHalf(1, 2); // ok
Rational result = onHalf * oneEight; // ok
result = oneEight * 2; // ok
result = 2 * oneEight; // wrong
}
其中我们用了3行乘法,前两个是对的,最后一个报错。
首先,我们自己写的重载接受的是个Rational类型,所以第一个肯定没问题。第二个虽然右边是个int,但是这里进行了隐式转换,用2构造了一个Rational对象。至于3为什么报错,可以这样看
resualt = oneEight.operator*(2);
resualt = 2.operator*(oneEight);
这样就很清晰了。但是有理数的乘法满足交换律是理所当然的,我们希望支持这样操作。将operaotr*设置为非成员函数即可。
友元还是非友元
能不友元就不要友元,破坏封装性。

浙公网安备 33010602011771号