c++中的基本型別可以使用+,-
等運算子對其直接進行操作,這樣非常方便。但是預設情況下不能直接用運算子對物件進行操作。例如:
class stock;
對於這個類的物件,如果我們想將兩個物件的price
成員的值相加,就只能定義乙個sum()
函式來實現操作。這樣我們在使用的時候也要呼叫這個函式。注意運算子的左側為呼叫物件,右邊是被呼叫的物件
。
但是通過過載運算子,我們可以直接將這個操作用操作符來表示,例如:
stock s1(23);
stock s2(34);
stock s = s1 + s2;
這樣可以使**更加整潔優雅。
運算子的過載有兩種實現方法,一種是在類內實現,另一種是在類外通過友元的方式實現。
在類內實現的格式為:
returntype operatorop (argumentlist)
其中op
就是需要過載的運算子,在實際應用中的例項為:
class stock;
stock stock::operator+(stock s) const
這樣就能直接用+
運算子對stock
類進行運算,如:
stock x = stock(23);
stock y(23);
stock z = x + y;
運算子過載的本質是乙個函式,當編譯器檢測到運算子的運算元是stock
類時,就會自動呼叫對應的運算子過載函式。
另乙個實現運算子過載的方式是在類外實現,利用友元
的方式。在有些情況下,類內實現的方式不能滿足需求。例如,對於這種情況:
stock s1(23);
stock s = 2 * s1;
注意運算子的左邊是呼叫物件,這時呼叫物件int
需要訪問s1
中的price
物件,但是price
是乙個private
物件,不能被直接訪問,這時就需要利用友元的方式實現運算子的過載,從而讓int
物件可以直接訪問stock
物件中的private
成員。其語法為:
class stock
//定義函式的時候不需要加friend關鍵字
stock operator*(double m, const stock & s)
在對運算子進行過載的時候有一些需要注意的點: 運算子過載之過載型別運算子
普通型別 類型別 呼叫對應的只有乙個引數 引數的型別就是這個普通型別 的建構函式 需求 boy boy1 10000 薪資 建構函式boy int boy boy2 rock 姓名 建構函式boy char 普通型別賦值給類型別其實很簡單,就是專門的對這個賦值的型別定義乙個建構函式。編譯器在執行 的...
運算子過載 賦值運算子的過載
有時候希望賦值運算子兩邊的型別可以不匹配,比如,把乙個int型別變數賦值給乙個complex物件,或把乙個 char 型別的字串賦值給乙個字串物件,此時就需要過載賦值運算子 注意 賦值運算子 只能過載為成員函式 賦值運算子過載例項示例 include include using namespace ...
運算子過載
c 中的運算子 1。大多數系統預定義運算子都能過載 不值得過載 不能被過載 2過載不能改變優先順序 不能改變結合性 不能改變運算子所需運算元的個數 過載後,可按這些運算子的表達方式使用 運算子過載的語法 一 通過運算子過載函式進行過載 1。運算子過載函式是成員函式 語法形式 type x opera...