C++ 运算符重载规则
運算符重載是通過函數重載實現的,下面我們來介紹一下運算符重載需要遵循的規則。
1 并不是所有的運算符都可以重載。能夠重載的運算符包括:
+ - * / % ^ & | ~ ! = < > += -= *= /= %= ^= &= |= << >> <<= >>= == != <= >= && || ++ -- , ->* -> () [] new new[] delete delete[]上述運算符中,[]是下標運算符,()是函數調用運算符。自增自減運算符的前置和后置形式都可以重載。長度運算符sizeof、條件運算符: ?、成員選擇符.和域解析運算符::不能被重載。
2 重載不能改變運算符的優先級和結合性。假設上一節的 complex 類中重載了+號和*號,并且 c1、c2、c3、c4 都是 complex 類的對象,那么下面的語句:
c4 = c1 + c2 * c3;等價于:
c4 = c1 + ( c2 * c3 );乘法的優先級仍然高于加法,并且它們仍然是二元運算符。
3 重載不會改變運算符的用法,原有幾個操作數、操作數在左邊還是在右邊,這些都不會改變。例如~號右邊只有一個操作數,+號總是出現在兩個操作數之間,重載后也必須如此。
4 運算符重載函數不能有默認的參數,否則就改變了運算符操作數的個數,這顯然是錯誤的。
5 運算符重載函數既可以作為類的成員函數,也可以作為全局函數。
將運算符重載函數作為類的成員函數時,二元運算符的參數只有一個,一元運算符不需要參數。之所以少一個參數,是因為這個參數是隱含的。
complex 類中重載了加法運算符:
complex operator+(const complex & A) const;當執行:
c3 = c1 + c2;會被轉換為:
c3 = c1.operator+(c2);通過 this 指針隱式的訪問 c1 的成員變量。
將運算符重載函數作為全局函數時,二元操作符就需要兩個參數,一元操作符需要一個參數,而且其中必須有一個參數是對象,好讓編譯器區分這是程序員自定義的運算符,防止程序員修改用于內置類型的運算符的性質。
如果有兩個參數,這兩個參數可以都是對象,也可以一個是對象,一個是C ++內置類型的數據,例如:
complex operator+(int a, complex &c){return complex(a+c.real, c.imag); }它的作用是使一個整數和一個復數相加。
另外,將運算符重載函數作為全局函數時,一般都需要在類中將該函數聲明為友元函數。原因很簡單,該函數大部分情況下都需要使用類的 private 成員。
上節的最后一個例子中,我們在全局范圍內重載了+號,并在 complex 類中將運算符重載函數聲明為友元函數,因為該函數使用到了 complex 類的 m_real 和 m_imag 兩個成員變量,它們都是 private 屬性的,默認不能在類的外部訪問。
6 箭頭運算符->、下標運算符[ ]、函數調用運算符( )、賦值運算符=只能以成員函數的形式重載。
總結
以上是生活随笔為你收集整理的C++ 运算符重载规则的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Java析构方法
- 下一篇: vc6.0mfc中单选按钮如何分组_按钮