/*#include<iostream>
using namespace std; */
#include<iostream.h>
class Complex
{ public:
Complex(float r, float i): real(r), image(i) {}
//If any constuctor is not defined, default constuctor will work.
//Otherwise, it has to be defined
Complex() {real=0; image=0;}
void display()
{ cout<<"("<<real<<","<<image<<"i)"<<endl;}
friend Complex operator + (const Complex &, const Complex &);
Complex(float r){real=r; image=0;}
private:
float real, image;
};
Complex operator + (const Complex & cmp1, const Complex & cmp2)
/*上面这句一旦改成“Complex operator + (Complex & cmp1, Complex & cmp2)”将出现编译不通过,原因是因为c++编译器的一个关于语义的限制。如果一个参数是以非const引用传 入,c++编译器就有理由认为程序员会在函数中修改这个值,并且这个被修改的引用在函数返回后要发挥作用。但如果你把一个临时变量当作非const引用参 数传进来,由于临时变量的特殊性,程序员并不能操作临时变量,而且临时变量随时可能被释放掉,所以,一般说来,修改一个临时变量是毫无意义的,据 此,c++编译器加入了临时变量不能作为非const引用的这个语义限制,意在限制这个非常规用法的潜在错误。
*/
{ return Complex(cmp1.real + cmp2.real, cmp1.image + cmp2.image);
}
int main()
{Complex c1(3,4),c2(5,-10),c3;
//Complex &test = c3;
float i=5.0f;
c3=c1+c2;
cout<<"c1+c2=";
c3.display();
c3=i+c1;
cout<<"i+c1=";
c3.display();
c3=c1+i;
cout<<"c1+i=";
c3.display();
return 0;
}
摘自:
http://blog.youkuaiyun.com/kongying168/archive/2009/02/05/3864756.aspx
http://blog.youkuaiyun.com/fxpbupt/archive/2010/01/07/5154190.aspx

被折叠的 条评论
为什么被折叠?



