運算子過載實質上是函式的過載
過載運算子的函式一般格式如下:
函式型別 operator 運算子名稱 (形參表列)
例如,想將「+」用於complex(複數)的加法運算,函式的原型可以是這樣的:
複製** **如下:
complex operator + (complex & c1,complex &c2);
其中,operator是關鍵字,時候專門用於定義過載運算子的函式的,運算子名稱就是c++提供給使用者的預定運算子。
注意:函式名是由operator和運算子組成。
上面的operator+就是函式名,意思是「對運算子+過載「。只要掌握這點,這可以發現,這類函式和其他函式在形式上沒有什麼區別。
兩個形參是complex類物件的引用,要求實參為complex類物件。
在定義了過載運算子www.cppcns.com後,可以說:函式operator+過載了運算子+。
在執行複數相加的表示式c1+c2時(假設c1+c2都已被定義為complex),系統就會呼叫operator+函式,把c1+c2作為實參,與形參進行虛實結合。
為了說明把運算子過載後,執行表示式就是呼叫函式的過程,可以把兩個整數相加也想象稱為呼叫下面的函式:
複製** **如下:
int operator + (int a,int b)
如果有表示式5+8,就呼叫此函式,將5和8作為呼叫函式時的形參,函式的返回值為13,這就是通過函式的方法理解運算子。
********************=示例**1.1******************************====
複製** **如下:
#include
using namespace std;
class complex
complex(double r,double i)
complex operator + (complex &c2);//宣告運算子的"+"函式
void display();
private:
double real;
double imag;
};complex complex::operator+(complex &c2)
void complex::display()
int main()
分析:在main函式中,「c3=c1+c2;」在將運算子+過載為類的成員函式後,c++編譯系統將程式中的表示式c1+c2解釋為:
c1.operator+(c2);//其中c1+c2是complex類的物件
即以c2為實參呼叫c1的運算子過載函式operator+(complex & c2),進行求值,得到兩個複數之和。上面的「operator+」是乙個函式名,它是類kwbimcomplex的成員函式。
在實際工作中,類的宣告和類的使用往往是分離的。假如在宣告complex類時,對運算子+,-,*,/都進行了過載,那麼使用這個類的使用者在程式設計時可以完全不考慮函式是怎麼實現的,
放心大膽地直接使用+,-,*,/進行複數的運算即可,顯然十分程式設計客棧方便。
對上面的運算子過載函式operator +還可以改寫的更簡練一些:
複製** **如下:
complex complex::operator+(complex &c2)
return語句中的complex(c2.real+real,c2.imag+imag)是建立乙個臨時物件,它沒有物件名,是乙個無名物件。
在建立臨時物件過程中,呼叫建構函式。return語句將此臨時物件作為函式返回值。
那麼,我們將+運算子進行了過載以後,可否將乙個常量和乙個複數相加呢?比如:
複製** **如下:
c3=3+c2; //錯誤,與形參型別不匹配
這是行不通的,因為我們定義operator +函式的時候,形參是兩個complex的物件,也就是說,實參和形參匹配才可以呼叫函式。
應寫成物件形式,如:
複製** **如下:
c3=complex(3,0)+c2; //正確,型別均為物件
還需要說明的是:運算子被過載後,其原有的功能仍然保留,沒有喪失或改變。
例如,運算子+被過載以後,仍然可以用於int,float,double,char型別資料的運算,同時又增加了用於複數相加的功能。
編譯系統根據表示式的上下文,即根據運算子兩側(如果是單目運算子則為一側)的資料型別決定的。
如,對於3+5,則執行整數加法;對於3.4+5.45,則執行雙精度數加法;對於兩個複數類相加,則執行複數加法。
本文標題: c++運算子過載的方法詳細解析
本文位址:
C 運算子過載的方法
運算子過載的方法是定義乙個過載運算子的函式,在需要執行被過載的運算子時,系統就自動呼叫該函式,以實現相應的運算。也就是說,運算子過載是通過定義函式實現的。運算子過載實質上是函式的過載 過載運算子的函式一般格式如下 函式型別 operator 運算子名稱 形參表列 例如,想將 用於complex 複數...
C 運算子過載 炒雞詳細
c 函式過載 過載宣告是指乙個與之前已經在該作用域內宣告過的函式或方法具有相同名稱 的宣告,但是它們的引數列表和定義 實現 不相同。當您呼叫乙個過載函式 時,編譯器通過把您所使用的引數型別與定義中的引數型別進行比較,決定選用最合適的定義。c 運算子過載 只有自定義的資料型別才可以實現運算子過載 幾種...
C 運算子過載 過載特殊運算子
賦值運算子用於同類物件間的相互賦值。賦值運算子只能被過載為類的非靜態成員函式,不能過載為友元函式和普通函式。對於使用者自定義的類而言,如果沒有過載賦值運算子,那麼c 編譯器會為該類提供乙個預設的過載賦值運算子成員函式。預設賦值運算子的工作方式是按位對拷,將等到右邊物件的非靜態成員拷貝給等號左邊的物件...