運算子過載機制(下篇)

2021-06-21 20:50:27 字數 997 閱讀 4041

我們將complex的運算子都定義為以型別complex為引數,對於complex運算子,各個運算物件都需要複製。然而對於大型物件來說,複製時的開銷是很恐怖的,所以為了避免過度複製,我們有兩個解決辦法:

1 定義以引用為引數的函式。

例如:

class matrix;

引用時我們能對大型物件使用所涉到各種常見運算子的表示式,而又能避免過度複製。在這裡不能使用指標,因為不能針對指標重定義運算子的意義。返回值是物件的引用,看起來合法,並且更加有效,然而這樣做卻會帶來儲存分配問題。乙個結果的引用將被函式作為到返回值的引用傳出來。這個返回值不能是自動變數,因此解決上述問題我們可以使用下面一種方法。

2 採用乙個靜態物件緩衝區,避免複製結果。

const int max_size = 10;

matrix &get_matrix()

matrix & operator + (const matrix &arg1,const matrix & arg2)

現在只有表示式的結果賦值時需要複製matrix,當然,要是寫出乙個表示式,其中涉及臨時變數多餘max_size ,只有老天能幫你了。

1 間接 

間接運算子->可以被定義為乙個一元的字尾運算子。直接看例子:

class x;

class ptr

void f(ptr p)

};

看上去m就跟ptr的成員一樣,是不是很有意思?

2  另乙個很有意思的事情是如何實現a**b等價於a的b次方

上面的式子可以這樣看 a*(*b)。

class b

};class a

friend int operator *(int a, int b)

};

a   a;

b   b;

a ** b //a的b次方

運算子過載之過載型別運算子

普通型別 類型別 呼叫對應的只有乙個引數 引數的型別就是這個普通型別 的建構函式 需求 boy boy1 10000 薪資 建構函式boy int boy boy2 rock 姓名 建構函式boy char 普通型別賦值給類型別其實很簡單,就是專門的對這個賦值的型別定義乙個建構函式。編譯器在執行 的...

運算子過載 賦值運算子的過載

有時候希望賦值運算子兩邊的型別可以不匹配,比如,把乙個int型別變數賦值給乙個complex物件,或把乙個 char 型別的字串賦值給乙個字串物件,此時就需要過載賦值運算子 注意 賦值運算子 只能過載為成員函式 賦值運算子過載例項示例 include include using namespace ...

運算子過載

c 中的運算子 1。大多數系統預定義運算子都能過載 不值得過載 不能被過載 2過載不能改變優先順序 不能改變結合性 不能改變運算子所需運算元的個數 過載後,可按這些運算子的表達方式使用 運算子過載的語法 一 通過運算子過載函式進行過載 1。運算子過載函式是成員函式 語法形式 type x opera...