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