C++ 過載運算子和過載函式

C++ 過載運算子和過載函式

C++ 允許在同一作用域中的某個函式運算子指定多個定義,分別稱為函式過載運算子過載

過載宣告是指一個與之前已經在該作用域內宣告過的函式或方法具有相同名稱的宣告,但是它們的引數列表和定義(實現)不相同。

當您呼叫一個過載函式過載運算子時,編譯器通過把您所使用的引數型別與定義中的引數型別進行比較,決定選用最合適的定義。選擇最合適的過載函式或過載運算子的過程,稱為過載決策

C++ 中的函式過載

在同一個作用域內,可以宣告幾個功能類似的同名函式,但是這些同名函式的形式引數(指引數的個數、型別或者順序)必須不同。您不能僅通過返回型別的不同來過載函式。

下面的例項中,同名函式 print() 被用於輸出不同的資料型別:

例項

#include <iostream> using namespace std; class printData { public: void print(int i) { cout << "整數為: " << i << endl; } void print(double f) { cout << "浮點數為: " << f << endl; } void print(char c[]) { cout << "字串為: " << c << endl; } }; int main(void) { printData pd; // 輸出整數 pd.print(5); // 輸出浮點數 pd.print(500.263); // 輸出字串 char c[] = "Hello C++"; pd.print(c); return 0; }

當上面的程式碼被編譯和執行時,它會產生下列結果:

整數為: 5
浮點數為: 500.263
字串為: Hello C++

C++ 中的運算子過載

您可以重定義或過載大部分 C++ 內建的運算子。這樣,您就能使用自定義型別的運算子。

過載的運算子是帶有特殊名稱的函式,函式名是由關鍵字 operator 和其後要過載的運算子符號構成的。與其他函式一樣,過載運算子有一個返回型別和一個引數列表。

Box operator+(const Box&);

宣告加法運算子用於把兩個 Box 物件相加,返回最終的 Box 物件。大多數的過載運算子可被定義為普通的非成員函式或者被定義為類成員函式。如果我們定義上面的函式為類的非成員函式,那麼我們需要為每次操作傳遞兩個引數,如下所示:

Box operator+(const Box&, const Box&);

下面的例項使用成員函式演示了運算子過載的概念。在這裡,物件作為引數進行傳遞,物件的屬性使用 this 運算子進行訪問,如下所示:

例項

#include <iostream> using namespace std; class Box { public: double getVolume(void) { return length * breadth * height; } void setLength( double len ) { length = len; } void setBreadth( double bre ) { breadth = bre; } void setHeight( double hei ) { height = hei; } // 過載 + 運算子,用於把兩個 Box 物件相加 Box operator+(const Box& b) { Box box; box.length = this->length + b.length; box.breadth = this->breadth + b.breadth; box.height = this->height + b.height; return box; } private: double length; // 長度 double breadth; // 寬度 double height; // 高度 }; // 程式的主函式 int main( ) { Box Box1; // 宣告 Box1,型別為 Box Box Box2; // 宣告 Box2,型別為 Box Box Box3; // 宣告 Box3,型別為 Box double volume = 0.0; // 把體積儲存在該變數中 // Box1 詳述 Box1.setLength(6.0); Box1.setBreadth(7.0); Box1.setHeight(5.0); // Box2 詳述 Box2.setLength(12.0); Box2.setBreadth(13.0); Box2.setHeight(10.0); // Box1 的體積 volume = Box1.getVolume(); cout << "Volume of Box1 : " << volume <<endl; // Box2 的體積 volume = Box2.getVolume(); cout << "Volume of Box2 : " << volume <<endl; // 把兩個物件相加,得到 Box3 Box3 = Box1 + Box2; // Box3 的體積 volume = Box3.getVolume(); cout << "Volume of Box3 : " << volume <<endl; return 0; }

當上面的程式碼被編譯和執行時,它會產生下列結果:

Volume of Box1 : 210
Volume of Box2 : 1560
Volume of Box3 : 5400

可過載運算子/不可過載運算子

下面是可過載的運算子列表:

雙目算術運算子 + (加),-(減),*(乘),/(除),% (取模)
關係運算符 ==(等於),!= (不等於),< (小於),> (大於),<=(小於等於),>=(大於等於)
邏輯運算子 ||(邏輯或),&&(邏輯與),!(邏輯非)
單目運算子 + (正),-(負),*(指標),&(取地址)
自增自減運算子 ++(自增),--(自減)
位運算子 | (按位或),& (按位與),~(按位取反),^(按位異或),,<< (左移),>>(右移)
賦值運算子 =, +=, -=, *=, /= , % = , &=, |=, ^=, <<=, >>=
空間申請與釋放 new, delete, new[ ] , delete[]
其他運算子 ()(函式呼叫),->(成員訪問),,(逗號),[](下標)

下面是不可過載的運算子列表:

  • .:成員訪問運算子
  • .*, ->*:成員指標訪問運算子
  • :::域運算子
  • sizeof:長度運算子
  • ?::條件運算子
  • #: 預處理符號

運算子過載例項

下面提供了各種運算子過載的例項,幫助您更好地理解過載的概念。

序號運算子和例項
1一元運算子過載
2二元運算子過載
3關係運算符過載
4輸入/輸出運算子過載
5 ++ 和 -- 運算子過載
6賦值運算子過載
7函式呼叫運算子 () 過載
8下標運算子 [] 過載
9類成員訪問運算子 -> 過載