無論前++(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...