返回:贺老师课程教学链接
下面的程序,想在main函数中要完成实数加复数、复数加实数,不可以。编译下面的程序出现错误,就是因为没有提供对应类型数据的运算符重载函数。
#include <iostream>
using namespace std;
class Complex
{
public:
Complex():real(0), imag(0){}
Complex(double r,double i):real(r), imag(i){}
Complex operator+(const Complex &c2);
void display();
private:
double real;
double imag;
};
//复数相加: (a+bi)+(c+di)=(a+c)+(b+d)i
Complex Complex::operator+(const Complex &c2)
{
Complex c;
c.real=real+c2.real;
c.imag=imag+c2.imag;
return c;
}
void Complex::display()
{
cout<<"("<<real<<","<<imag<<"i)"<<endl;
}
//下面定义用于测试的main()函数
int main()
{
Complex c1(3,4),c2,c3;
c2=2.5+c1;
c3.display();
c3=c1+2.5;
c3.display();
return 0;
}
解决方案1:增加实数加复数、复数加实数的运算符重载函数,详见《
复数类重载》中的第(3)部分。
解决方案2:设计转换构造函数。将2.5之类的实数,转换为实部为2.5的复数(符合数学中的定义),然后进行运算。
类定义为:
class Complex
{
public:
Complex():real(0), imag(0){}
Complex(double r):real(r), imag(0){} //转换构造函数
Complex(double r,double i):real(r), imag(i){}
Complex operator+(const Complex &c2);
void display();
private:
double real;
double imag;
};
当main函数不改变时,错误仍然在。这说明,系统不会自动在2.5+c1时,自动将2.5转换为复数类的对象。
当将main函数改为如下形式时,运算顺利进展:
int main()
{
Complex c1(3,4),c2,c3;
c2=Complex(2.5)+c1;
c2.display();
c3=c1+Complex(2.5);
c3.display();
return 0;
}
Complex(2.5)?这不就是强制类型转换吗?int(2.5)还记得否,强制将2.5转换为int型!
解决方案3:设计类型转换函数。类的定义如下:
class Complex
{
public:
Complex():real(0), imag(0){}
operator double( ) {return real;} //类型转换函数
Complex(double r,double i):real(r), imag(i){}
Complex operator+(const Complex &c2);
void display();
private:
double real;
double imag;
};
若用原main函数测试,仍然有错。请思考为什么?也可以在看完下文后再思考。
main函数如下改:
int main()
{
Complex c1(3,4);
double d2,d3;
d2=2.5+c1;
cout<<d2<<endl;
d3=c1+2.5;
cout<<d3<<endl;
return 0;
}
程序编译没有问题。operator double( ) 类型转换函数的定义,其实支持了Complex类型向double的自动类型转换。
只是遗憾的是,复数中的虚部,在转换中被丢掉了。
从这篇文章中,我们可以看出转换构造函数与类型转换函数的用法,以及应用的场合。