C 運算子過載

2021-06-07 16:00:42 字數 899 閱讀 1651

(1)運算子++和—(減減)分為字首和字尾,過載為字尾時,

在函式的引數表裡新增乙個int型的標識引數,以便和字首過載區分。

(2)賦值=運算子僅允許作為成員函式過載,不能過載為友元函式,此時要判斷是否是自賦值。

(3)下標運算子也必須是成員函式並且需要單個引數,經常返回乙個引用。

(4)運算子()必須被過載為成員函式,其引數可以有任意個,它使得物件看起來像乙個真正的函式名,即函式物件。

(5)返回效率

當為通過傳值方式返回而建立乙個新物件時,要注意使用的形式。例如用運算子+號:

return integer(left.i + right.i);

一開始看起來像是"對乙個建構函式的呼叫",但其實並非如此。這是臨時物件語法,

它是這樣陳述的:「建立乙個臨時物件並返回它」。因為這個原因,我們可能認為

如果建立乙個命名的區域性物件並返回它,結果將會是一樣的。其實不然。如果

像下面這樣表示,將發生三件事。首先,tm物件被建立,與此同時它的建構函式被

呼叫。然後,拷貝建構函式把tmp拷貝到返回值外部儲存單元裡。最後,當tmp在作用

域的結尾時呼叫析構函式。

integer tmp(left.i + right.i);

return tmp;

相反,"返回臨時物件"的方法是完全不同的。看到這樣的情況時,編譯器明白對建立的

物件沒有其它需求,只是返回它,所以編譯器直接把這個物件建立在返回值外面的儲存

單元裡。因為不是正真建立乙個區域性物件,所以僅需要單個的普通構造函式呼叫(不需

要拷貝建構函式)並且不會呼叫析構函式。因此,這種方法不需要什麼開銷,效率是非常高的。

C 運算子過載 過載特殊運算子

賦值運算子用於同類物件間的相互賦值。賦值運算子只能被過載為類的非靜態成員函式,不能過載為友元函式和普通函式。對於使用者自定義的類而言,如果沒有過載賦值運算子,那麼c 編譯器會為該類提供乙個預設的過載賦值運算子成員函式。預設賦值運算子的工作方式是按位對拷,將等到右邊物件的非靜態成員拷貝給等號左邊的物件...

C 運算子過載賦值運算子

自定義類的賦值運算子過載函式的作用與內建賦值運算子的作用類似,但是要要注意的是,它與拷貝建構函式與析構函式一樣,要注意深拷貝淺拷貝的問題,在沒有深拷貝淺拷貝的情況下,如果沒有指定預設的賦值運算子過載函式,那麼系統將會自動提供乙個賦值運算子過載函式。賦值運算子過載函式的定義與其它運算子過載函式的定義是...

C 運算子過載轉換運算子

為什麼需要轉換運算子?大家知道對於內建型別的資料我們可以通過強制轉換符的使用來轉換資料,例如 int 2.1f 自定義類也是型別,那麼自定義類的物件在很多情況下也需要支援此操作,c 提供了轉換運算子過載函式 它使得自定義類物件的強轉換成為可能。轉換運算子的生命方式比較特別,方法如下 operator...