/*条款46:需要类型转换时请为模板定义非成员函数*/
#include<iostream>
using namespace std;
template<typename T>
class Rational{
public:
Rational(const T&numerator=0,const T&denominator=1):a(numerator),b(denominator){
}
const T numerator()const{
return a;
}
const T denominator()const{
return b;
}
//..
friend const Rational<T>/*加不加<T>一样*/ operator*(const Rational&lhs,const Rational&rhs){
return Rational(lhs.numerator()*rhs.numerator(),lhs.denominator()*rhs.denominator());
}//把它非成员放在类内声明缓和了模板参数推导时的隐式推断,让编译器在类的具现化时得到T,但在这里我们也必须履行声明带来的额外条件,要去定义它,尽管它是非成员函数,这样就不会再报错了
friend ostream &operator<<(ostream&os,const Rational&rhs){
return os<<rhs.a<<'/'<<rhs.b<<endl;
}
private:
T a;
T b;
};
template<typename T>
ostream &operator<<(ostream&os,const Rational<T>&rhs);
template<typename T>
const Rational<T> operator*(const Rational<T>&lhs,const Rational<T>&rhs);
int main(){
Rational<int> oneHalf(1,2);
Rational<int>result = oneHalf*2;//如果是非模板类型可以通过,因为模板参数的推导不再允许有隐式推导
cout<<result;
return 0;
}
条款46:需要类型转换时请为模板定义非成员函数
最新推荐文章于 2023-07-09 12:31:42 发布