定義為成員函式時:
定義為全域性函式
自增和自減運算子
所有賦值運算子均改變左值,為了使賦值結果能用於鏈式表示式,如a=b=c,應該返回乙個改變了左值的引用。一般賦值運算子的返回值是非const 引用,以便能對剛剛賦值的物件進行運算。
邏輯運算子和關係運算子最好返回bool 值,也可以返回 int 值。
返回值優化
return
complex
(real,imaginary)
;
通過傳值方式返回建立新物件時,使用一種新語法。上述語句看起來像乙個構造函式呼叫,稱為臨時物件語法,其行為是建立乙個臨時的complex物件並返回它。不用呼叫拷貝建構函式和析構函式,效率更高。
使用成員運算子的限制是左運算元必須是當前類的物件,左運算元不能進行自動型別轉換,而全域性運算子為兩個運算元都提供了轉換的可能性。如以下程式:
#include
using namespace std;
class number
const number operator+
(const number& n)
const
friend const number operator-
(const number&
,const number&);
};const number operator-
(const number& n1,
const number& n2)
intmain()
定義乙個虛數類,實現虛數類的加(+
++)、減(−
-−)、乘(*)、除(/)、共軛(~);其中加、減、共軛定義為全域性函式,乘除定義為全域性函式。
class complex
void
getcomplex()
complex& operator+
(const complex& a)
complex& operator-
(const complex& a)
complex operator~()
friend complex operator*
(const complex&
,const complex&);
friend complex operator/
(const complex&
,const complex&);
};complex operator*
(const complex& a,
const complex& b)
complex operator/
(const complex& a,
const complex& b)
C 運算子過載 過載特殊運算子
賦值運算子用於同類物件間的相互賦值。賦值運算子只能被過載為類的非靜態成員函式,不能過載為友元函式和普通函式。對於使用者自定義的類而言,如果沒有過載賦值運算子,那麼c 編譯器會為該類提供乙個預設的過載賦值運算子成員函式。預設賦值運算子的工作方式是按位對拷,將等到右邊物件的非靜態成員拷貝給等號左邊的物件...
C 運算子過載賦值運算子
自定義類的賦值運算子過載函式的作用與內建賦值運算子的作用類似,但是要要注意的是,它與拷貝建構函式與析構函式一樣,要注意深拷貝淺拷貝的問題,在沒有深拷貝淺拷貝的情況下,如果沒有指定預設的賦值運算子過載函式,那麼系統將會自動提供乙個賦值運算子過載函式。賦值運算子過載函式的定義與其它運算子過載函式的定義是...
C 運算子過載轉換運算子
為什麼需要轉換運算子?大家知道對於內建型別的資料我們可以通過強制轉換符的使用來轉換資料,例如 int 2.1f 自定義類也是型別,那麼自定義類的物件在很多情況下也需要支援此操作,c 提供了轉換運算子過載函式 它使得自定義類物件的強轉換成為可能。轉換運算子的生命方式比較特別,方法如下 operator...