问题及代码:
/*
*Copyright (c) 2015,烟台大学计算机学院
*All rights reserved.
*文件名称:test.cpp
*作者:吴胜男
*完成日期:2015年04月15日
*版本号:v1.0
*
*问题描述:(3)友元函数提供了一种非成员函数访问私有数据成员的途径,模板类使类中的数据成员的类型变得灵活,这两种技术可以结合起来用。
要求在前面方案的基础上支持用友员函数实现的加法。用于测试的main()函数如下:
*输入描述:略
*程序输出:略
*/
#include <iostream>
#include <vector>
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);
template <class T1> friend Complex<T1> add_complex(Complex<T1> &c1,Complex<T1> &c2);
void display();
private:
T real;
T imag;
};
template <class T>
void Complex<T>::display()
{
cout<<"("<<real<<","<<imag<<"i)"<<endl;
}
template<class T> //每一个成员函数的定义前,必须要声明类模板
Complex<T> Complex<T>::complex_add(Complex<T> &c2) //使用了模板的类,将不再独立使用,其类名的完整表示为“类模板名<虚拟类型参数>”
{
Complex<T> c;
c.real=real+c2.real;
c.imag=imag+c2.imag;
return c;
}
template<class T> //每一个成员函数的定义前,必须要声明类模板
Complex<T> add_complex(Complex<T> &c1,Complex<T> &c2) //使用了模板的类,将不再独立使用,其类名的完整表示为“类模板名<虚拟类型参数>”
{
Complex<T> 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;
}
运行结果:
知识点总结:在类模板中声明成员函数之前加上类名。在声明友元函数时形式为template <class T1> friend Complex<T1> add_complex(Complex<T1> &c1,Complex<T1> &c2); 应该注意的是将虚拟类型名与声明类模板时的虚拟函数名区分开。
学习心得:总感觉一些知识点弄得稀里糊涂的,但又不知道问题出在哪里。很是郁闷啊!很欠缺啊!!最可怕的就是自己学的不行,就是不知道怎么补。