友元函数提供了一种非成员函数访问私有数据成员的途径,模板类使类中的数据成员的类型变得灵活,这两种技术可以结合起来用。要求在前面方案的基础上支持用友员函数实现的加法。用于测试的main()函数如下:
[cpp] view plaincopyprint?在CODE上查看代码片派生到我的代码片
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;
}
#include <iostream>
using namespace std;
template <class T>
class Complex
{
private:
T real;
T ima;
public:
Complex(T a=0,T b=0);
Complex complex_add(Complex & com);
<span style="font-size:18px;"><strong>template<class T1> friend Complex<T1> add_complex(const Complex <T1> &c1,const Complex <T1> &c2)</strong></span>;
void display();
};
<span style="font-size:14px;">template <class T>
Complex<T> add_complex(const Complex<T> &c1,const Complex<T> &c2)
{
Complex <T> c;
c.real=c1.real+c2.real;
c.ima=c1.ima+c2.ima;
return c;
}</span>
template <class T>
void Complex<T>::display()
{
cout<<"("<<real<<","<<ima<<")"<<endl;
}
template <class T>
Complex<T>::Complex(T a,T b)
{
real=a;
ima=b;
}
template <class T>
Complex <T> Complex<T>::complex_add(Complex <T>& com)
{
Complex<T> c;
c.real=real+com.real;
c.ima=ima+com.ima;
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;
}
在类中使用友元函数时声明需注意!!!!