码迷,mamicode.com
首页 > 其他好文 > 详细

第六周 【项目6-复数模板类】(3)

时间:2015-04-15 19:43:55      阅读:122      评论:0      收藏:0      [点我收藏+]

标签: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 发现就不对了,看来友元函数和这个类是不同的的,不能连在一起考虑的。回头还要好好看看书。

第六周 【项目6-复数模板类】(3)

标签:namespace   class   iostream   一周      

原文地址:http://blog.csdn.net/wh201458501106/article/details/45062019

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!