template以及operator*的正确用法

这是看《Effective c++》时在VS上玩的代码。

#include <iostream>
using namespace std;

template<typename T>
class Rational{
public:
	Rational(const T& numerator =0,const T& denominator = 1);
	const T numerator() const;//不暴露私有变量给调用者修改
	const T denominator() const;

	//为了让类型转换可能发生于所有实参身上,需要non-member函数;
	//为了让这个函数被自动具现化,需要将它声明在class内部
	friend const Rational operator*(const Rational& lhs,const Rational& rhs)
	{
		return Rational(lhs.numerator()*rhs.numerator(),lhs.denominator()*rhs.denominator());
	}
	/*
	如果类内提供声明:
	friend const Rational operator*(const Rational& lhs,const Rational& rhs);
	然后在外部提供定义式:
	template<typename T>
	const Rational<T> operator*(const Rational<T>& lhs,const Rational<T>& rhs)
	{
		return Rational(lhs.numerator()*rhs.numerator(),lhs.denominator()*rhs.denominator());
	}
	
	可是链接时不成功:无法解析的外部符号
	"class Rational<int> const __cdecl operator*(class Rational<int> const &,class Rational<int> const &)"
	*/
	 
	void print()
	{
		cout<<numerator()<<"/"<<denominator()<<endl;
	}
private:
	T num;
	T deno;
};




template<typename T>
Rational<T>::Rational(const T& numerator,const T& denominator)
{
	num = numerator;
	deno = denominator;
}

template<typename T>
const T Rational<T>::numerator()const {
	return num;
}

template<typename T>
const T Rational<T>::denominator()const {
	return deno;
}

int main()
{
	Rational<int> a (2,7);
	Rational<int> b = a*2;//2被转换成Rational(2),分子赋值为2,分母没值默认为1
	b.print();
	Rational<int>c =a*a;
	c.print();
return 0;
}


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值