标签: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