C++中不能重載的運算符

C++中不能重載的運算符有5個,分別爲:“?:” “.” “::” “sizeof” “.*” 。 
重載:讓操作符可以有新的語義,而不是更改語法,否則會引起混亂。 
重載的部分規則:運算函數的參數至少有一個必須是類的對象或者是類的對象的引用。

下面來i解釋一下爲什麼這幾個運算符不能進行重載。

(1)?:
假設可以重載,那麼我們來看下列的代碼:

exp1 ? exp2 : exp3

該運算符的含義是執行exp2和exp3中的一個,假設重載了,就不可以保證執行一個還是兩個,還是都沒執行,該運算符的跳轉性質就不復存在了。所以,“?:”不能被重載。

(2).
假設可以重載,我們可以假設一種情況,創建一個對象,調用該對象的函數。

class Y{
   public:
      void fun();
};
class X{
   public:
      Y* p;
      Y& operator.(){
          return *p;
      }
      void fun();
}
void g(X& x){
      x.fun();
}

這個例子中,x.fun()就不知道是調用哪一個fun函數了。 
“.”運算符的含義是引用對象成員,然而被重載後就不能保證了,導致運算符意義的混淆。

(3)::
該運算符只是在編譯的時候域解析,而沒有運算參與。根據重載的規則,如果重載該運算符,就賦予了新的語義,可能會出現混淆。

(4)sizeof
不能被重載的原因主要是內部許多指針都依賴sizeof。

(5).*
引用指向類成員的指針

 

重載運算符遵守的原則:
1. 被重載的操作符不可以通過連接其他符號來創建新的操作符。 
2. 重載操作符必須有一個類類型或者枚舉類型的操作數。 
3. 內置類型的操作符,含義不能改變,如整數加法(+)。 
4. 重載後的運算符不可以保證操作符的順序。 
5. 類成員的重載函數,其形參隱含一個默認的this指針。 
6. 一般將賦值運算符定義爲成員函數,將算數運算符定義爲非成員函數。 
7. 操作符定義爲非類的成員函數時,一般將其定義爲類的友元。 
8. == 與 != 要成對出現。 
9. 下標運算符[]:一個非const成員並返回引用,一個是const成員並返回引用。 
10. * 與 -> 操作符,不顯示任何參數。 
11. 前置 ++/-- 必須返回被增量或者減量的引用。 
12. 輸入操作符和輸出操作符必須定義爲類的友元函數。
--------------------- 
原文鏈接:https://blog.csdn.net/zwe7616175/article/details/80439870 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章