问题描述:
友元函数提供了一种非成员函数访问私有数据成员的途径,模板类使类中的数据成员的类型变得灵活,这两种技术可以结合起来用。要求在前面方案的基础上支持用友员函数实现的加法。
代码:
#include <iostream>
using namespace std;
template<class T>
class Complex
{
public:
Complex( )
{
real=0;
imag=0;
}
Complex(T r,T i)
{
real=r;
imag=i;
}
Complex complex_add(Complex &c2);
Complex complex_minus(Complex &c2);
Complex complex_multiply(Complex &c2);
Complex complex_divide(Complex &c2);
void display( );
template<class T1> friend Complex<T1> add_complex(Complex<T1> &c1,Complex<T1> &c2);
private:
T real;
T imag;
};
template<class T>
Complex<T> Complex<T>::complex_add(Complex &c2)
{
Complex<T> c;
c.real=real+c2.real;
c.imag=imag+c2.imag;
return c;
}
template<class T>
Complex<T> Complex<T>::complex_minus(Complex &c2)
{
Complex<T> c;
c.real=real-c2.real;
c.imag=imag-c2.imag;
return c;
}
template<class T>
Complex<T> Complex<T>::complex_multiply(Complex &c2)
{
Complex<T> c;
c.real=real*c2.real-imag*c2.imag;
c.imag=real*c2.imag+imag*c2.real;
return c;
}
//复数相除:(a+bi)/(c+di)=(ac+bd)/(c^2+d^2) +(bc-ad)/(c^2+d^2)i
template <class T>
Complex<T> Complex<T>::complex_divide(Complex <T> &c2)
{
Complex <T> c;
T d=c2.real*c2.real+c2.imag*c2.imag;
c.real=(real*c2.real+imag*c2.imag)/d; //此处有危险未排除:除法溢出
c.imag=(imag*c2.real-real*c2.imag)/d;
return c;
}
template<class T>
void Complex<T>::display()
{
cout<<"("<<real<<","<<imag<<"i"<<")"<<endl;
}
template<class T1>
Complex<T1> add_complex(Complex<T1> &c1,Complex<T1> &c2)
{
Complex<T1> c;
c.real=c1.real+c2.real;
c.imag=c1.imag+c2.imag;
return c;
}
int main( )
{
Complex<int> c1(3,4),c2(5,-10),c3;
c3=c1.complex_add(c2); //调用成员函数支持加法运算,有一个形参
cout<<"c1+c2=";
c3.display( );
Complex<double> c4(3.1,4.4),c5(5.34,-10.21),c6;
c6=c4.complex_add(c5); //调用成员函数支持加法运算,有一个形参
cout<<"c4+c5=";
c6.display( );
Complex<int> c7;
c7=add_complex(c1,c2); //调用友员函数支持加法运算,有两个形参
cout<<"c1+c2=";
c7.display( );
Complex<double> c8;
c8=add_complex(c4,c5); //调用友员函数支持加法运算,有两个形参
cout<<"c4+c5=";
c8.display( );
return 0;
}
运行结果: