所謂重載,就是重新賦予新的含義。函數重載就是對一個已有的函數賦予新的含義,使之實現新功能,因此,一個函數名就可以用來代表不同功能的函數,也就是”一名多用”。
運算符也可以重載。實際上,我們已經在不知不覺之中使用了運算符重載。例如,大 家都已習慣于用加法運算符”+”對整數、單精度數和雙精度數進行加法運算,如5+8, 5.8 +3.67等,其實計算機對整數、單精度數和雙精度數的加法操作過程是很不相同的, 但由于C++已經對運算符”+”進行了重載,所以就能適用于int, float, doUble類型的運算。
又如”<<“是C++的位運算中的位移運算符(左移),但在輸出操作中又是與流對 象cout 配合使用的流插入運算符,”>>“也是位移運算符(右移),但在輸入操作中又是與流對象 cin 配合使用的流提取運算符。這就是運算符重載(operator overloading)。C++系統對”<<“和”>>“進行了重載,用戶在不同的場合下使用它們時,作用是不同 的。對”<<“和”>>“的重載處理是放在頭文件stream中的。因此,如果要在程序中用”<<“和”>>”作流插入運算符和流提取運算符,必須在本文件模塊中包含頭文件stream(當然還應當包括”using namespace std“)。
現在要討論的問題是:用戶能否根據自己的需要對C++已提供的運算符進行重載,賦予它們新的含義,使之一名多用。譬如,能否用”+”號進行兩個復數的相加。在C++中不能在程序中直接用運算符”+”對復數進行相加運算。用戶必須自己設法實現復數相加。例如用戶可以通過定義一個專門的函數來實現復數相加。
[例] 通過函數來實現復數相加。
#include <iostream>using namespace std;class Complex //定義Complex類{public: Complex( ){real=0;imag=0;} //定義構造函數 Complex(double r,double i){real=r;imag=i;} //構造函數重載 Complex complex_add(Complex &c2); //聲明復數相加函數 void display( ); //聲明輸出函數private: double real; //實部 double imag; //虛部};Complex Complex::complex_add(Complex &c2){ Complex c; c.real=real+c2.real; c.imag=imag+c2.imag; return c;}void Complex::display( ) //定義輸出函數{ cout<<"("<<real<<","<<imag<<"i)"<<endl;}int main( ){ Complex c1(3,4),c2(5,-10),c3;//定義3個復數對象 c3=c1.complex_add(c2); //調用復數相加函數 cout<<"c1="; c1.display( );//輸出c1的值 cout<<"c2="; c2.display( );//輸出c2的值 cout<<"c1+c2="; c3.display( );//輸出c3的值 return 0;}
運行結果如下:
c1=(3+4i)c2=(5-10i)c1+c2=(8,-6i)
結果無疑是正確的,但調用方式不直觀、太煩瑣,使人感到很不方便。能否也和整數的加法運算一樣,直接用加號”+”來實現復數運算呢?如
c3=c1+c2;
編譯系統就會自動完成c1和c2兩個復數相加的運算。如果能做到,就為對象的運算提供了很大的方便。這就需要對運算符”+“進行重載。
新聞熱點
疑難解答
圖片精選