标签:namespace class iostream 一周 类
运行代码:
/*
*Copyright (c)2014,烟台大学计算机与控制工程学院
*All rights reserved.
*dood luck
*文件名称:d.cpp
*作 者:张旺华
*完成日期:2015年4月15日
*版 本 号:v1.0
*
*/
//项目6-复数模板类】
//该例实现了一个复数类,但是美中不足的是,复数类的实部和虚部都固定只能是double型的。
//可以通过模板类的技术手段,设计Complex,使实部和虚部的类型为定义对象时指定的实际类型。
//(1)要求类成员函数在类外定义。
//(2)在此基础上,再实现减法、乘法和除法
//你可以使用的main()函数如下。
//(3)友元函数提供了一种非成员函数访问私有数据成员的途径,模板类使类中的数据成员的类型变得灵活,
//这两种技术可以结合起来用。要求在前面方案的基础上支持用友员函数实现的加法。用于测试的main()函数如下:
#include<iostream>
using namespace std;
template <class T>
class Complex
{
public :
Complex()
{
real=0;
imag=0;
}
Complex(T m,T n)
{
real=m;
imag=n;
}
template<class T2> friend Complex<T2> add_complex(const Complex<T2> &c1, const Complex<T2> &c2);
//利用了模板的外部函数要作为友元函数,注意声明方式:类声明中也必须给出模板声明。
//这一行程序可以在CodeBlocks中调试通过,将T2换成T1,VS2008也接受
Complex complex_add(Complex &);
Complex complex_minus(Complex &);
Complex complex_multiply(Complex &);
Complex complex_divide(Complex &);
void display();
private:
T real; //类声明中的每一个T,将被对象定义时提供的实际类型代替
T imag;
};
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 T2>
Complex<T2> add_complex(const Complex<T2> &m, const Complex<T2> &n)
{
Complex<T2> c;
c.real=m.real+n.real;
c.imag=m.imag+n.imag;
return c;
}
template <class T>
void Complex<T>::display()
{
cout<<'('<<real<<","<<imag<<"i)"<<endl;
}
template <class T>
Complex<T> Complex<T>:: complex_add(Complex &m)
{
Complex c;
c.real=real+m.real;
c.imag=imag+m.imag;
return c;
}
template <class T>
Complex<T> Complex<T>::complex_minus(Complex &m)
{
Complex c;
c.real=real-m.real;
c.imag=imag-m.imag;
return c;
}
template <class T>
Complex<T> Complex<T>::complex_multiply(Complex &m)
{
Complex c;
c.real=real*m.real+imag*m.imag;
c.imag=real*m.imag+imag*m.real;
return c;
}
template <class T>
Complex<T> Complex<T>::complex_divide(Complex &m)
{
Complex c;
T n=m.real*m.real-m.imag*m.imag;
c.real=(real*m.real+imag*m.imag)/n;
c.imag=(real*m.imag+imag*m.real)/n;
return c;
}
运行结果:
知识点运用:在模板 中使用 友元 函数,
学习 心得:一开始确实是不知道怎样做,各种各样的定义友元函数就是错误,还是回头看看老师。
template<class T1> friend Complex<T1> add_complex(const Complex<T1> &c1, const Complex<T1> &c2);
似懂非懂拿过来运行了一下,对了,再把T2改成T 发现就不对了,看来友元函数和这个类是不同的的,不能连在一起考虑的。回头还要好好看看书。
标签:namespace class iostream 一周 类
原文地址:http://blog.csdn.net/wh201458501106/article/details/45062019