条款46:需要类型转换时请为模板定义非成员函数——252

文章目录


将条款24的例子换成模板:

template<typename T>
class Rational{
public:
    Rational(cosnt T& numerator=0,
                const T& denominator=1);
    const T numerator() const;
    const T denominator() cosnt;
    ...
};
template<typename T>
const Rational<T> operator* (cosnt Rational<T>& lhs, const Rational<T>& rhs) { ... }

但是混合式算术运算在这里行不通:

Rational<int> oneHalf(1,2);
Rational<int> result=oneHalf*2; //error:无法通过编译

我们来换种写法:

template<typename T>
class Rational{
public:
    ...
    friend const Rational operator*(const Rational& lhs,const Rational& rhs);
};
template<typename T>
const Rational<T> operator* (cosnt Rational<T>& lhs, const Rational<T>& rhs) { ... }

现在混合式算术运算在这里可以通过编译,因为编译器知道我们要调用哪个函数。但是无法连接,因为那个函数只被声明与Rational内,并没有定义出来。因此可再次修改:

template<typename T>
class Rational{
public:
    ...
    friend const Rational operator*(const Rational& lhs,const Rational& rhs)
    {
        return Rational(lhs.numerator()*rhs.numerator(),
        lhs.denominator()*rhs.denominator());
    }
};

总结——256

当我们编写一个class template,而它所提供的的“与此template相关的”函数支持“所有参数的隐式类型转换”时,请将那些函数定义为“class template内部的friend函数”。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值