C++ 运算符de重载

//重载运算符使之拥有新的用法————用来计算复数;

#include<iostream.h>
class complex
{
public:
complex()
{real=imag=0;}
complex(double r,double i)
{
real=r;imag=i;
}
complex operator +(const complex &c);
    complex operator -(const complex &c);
    complex operator *(const complex &c);
complex operator /(const complex &c);
friend void print(const complex &c);
private:
double real,imag;
};
inline complex complex::operator +(const complex &c)
{
    return complex(real+c.real,imag+c.imag);


}
inline complex complex::operator -(const complex &c)
{
    return complex(real-c.real,imag-c.imag);


}
inline complex complex::operator *(const complex &c)
{
    return complex(real*c.real-imag*c.imag,real*c.imag+imag*c.real);
}
inline complex complex::operator /(const complex &c)
{
    return complex((real*c.real+imag*c.imag)/(c.real*c.real+c.imag*c.imag),(real*c.imag+imag*c.real)/(c.real*c.real+c.imag*c.imag));
}
void print(const complex &c)
{  if(c.imag<0)
  cout<<c.real<<c.imag<<'i';
   else
  cout<<c.real<<'+'<<c.imag<<'i';
}
void main()
{
   complex c1(2.0,3.0),c2(4.0,-2.0),c3;
   c3=c1+c2;
   cout<<endl<<"c1+c2=";
   print(c3);
   c3=c1-c2;
   cout<<endl<<"c1-c2=";
   print(c3);
   c3=c1*c2;
   cout<<endl<<"c1*c2=";
   print(c3);
   c3=c1/c2;
   cout<<endl<<"c1/c2=";
   print(c3);
  cout<<endl;
}


输出结果:

C++ 运算符de重载_第1张图片

下面是一些const的用法

const修饰的数据类型为常类型,常类型的变量或对象的值是不能被更新的。


const关键字的作用主要有以下几点:

(1)可以定义const常量,具有不可变性。 例如: 
const int Max=100; int Array[Max]; 
(2)便于进行类型检查,使编译器对处理内容有更多了解,消除了一些隐患。例如: void f(const int i) { .........} 编译器就会知道i是一个常量,不允许修改; 
(3)可以避免意义模糊的数字出现,同样可以很方便地进行参数的调整和修改。
(4)可以保护被修饰的东西,防止意外的修改,增强程序的健壮性。 还是上面的例子,如果在函数体内修改了i,编译器就会报错; 例如: 
void f(const int i) { i=10;//error! } 
(5) 为函数重载提供了一个参考。 
class A { ...... 
void f(int i) {......} //一个函数 
void f(int i) const {......} //上一个函数的重载 ...... 
}; 
(6) 可以节省空间,避免不必要的内存分配。 例如: 
#define PI 3.14159 //常量宏 
const doulbe Pi=3.14159; //此时并未将Pi放入ROM中 ...... 
double i=Pi; //此时为Pi分配内存,以后不再分配! 
double I=PI; //编译期间进行宏替换,分配内存 
double j=Pi; //没有内存分配 
double J=PI; //再进行宏替换,又一次分配内存! 
const定义常量从汇编的角度来看,只是给出了对应的内存地址,而不是象#define一样给出的是立即数,所以,const定义的常量在程序运行过程中只有一份拷贝,而#define定义的常量在内存中有若干个拷贝。 
(7) 提高了效率。 编译器通常不为普通const常量分配存储空间,而是将它们保存在符号表中,这使得它成为一个编译期间的常量,没有了存储与读内存的操作,使得它的效率也很高。

你可能感兴趣的:(C++,CONST的用法,运算符的重载)