運算子過載前 與後

2021-08-16 20:13:16 字數 703 閱讀 2350

無論前++(prefix)還是後++(postfix),運算元都只有乙個,這樣我們做運算子過載的時候,該如何區分呢?

這裡就要接受乙個新的知識,就是亞元。在c++ primer一書中是這樣描述的(中文版 第五版 503 頁)「為了解決這個問題,後置版本接受乙個額外的(不被使用)int型別的形參。

當我們使用後置運算子時,編譯器為這個形參提供乙個值為0的實參。儘管從語法上來說後置函式可以使用這個額外的形參,但是在實際過程中通常不會這麼做。這個形參唯一的作用就是區分前置版本和後置版本的函式,而不是真的要在實現後置版本時參與運算。」下面便是前++和後++的實現**,請注意兩種實現不同的區別,乙個是返回引用,乙個是返回臨時物件:

#include using namespace std;

class complex

void display()

// 一定要返回引用,因為++會改變運算元,而如果是臨時物件,運算元據的值不會變

// 前++

complex& operator++()

// 後++,在引數中隨便加乙個型別,表示是後++,稱為亞元

const complex operator++(int)

private:

float _x;

float _y;

};int main(int argc, char* argv)

運算子過載之過載型別運算子

普通型別 類型別 呼叫對應的只有乙個引數 引數的型別就是這個普通型別 的建構函式 需求 boy boy1 10000 薪資 建構函式boy int boy boy2 rock 姓名 建構函式boy char 普通型別賦值給類型別其實很簡單,就是專門的對這個賦值的型別定義乙個建構函式。編譯器在執行 的...

運算子過載 賦值運算子的過載

有時候希望賦值運算子兩邊的型別可以不匹配,比如,把乙個int型別變數賦值給乙個complex物件,或把乙個 char 型別的字串賦值給乙個字串物件,此時就需要過載賦值運算子 注意 賦值運算子 只能過載為成員函式 賦值運算子過載例項示例 include include using namespace ...

運算子過載

c 中的運算子 1。大多數系統預定義運算子都能過載 不值得過載 不能被過載 2過載不能改變優先順序 不能改變結合性 不能改變運算子所需運算元的個數 過載後,可按這些運算子的表達方式使用 運算子過載的語法 一 通過運算子過載函式進行過載 1。運算子過載函式是成員函式 語法形式 type x opera...