C 編譯時多型 運算子過載

2021-08-17 20:43:03 字數 1719 閱讀 5326

1、運算子過載的本質

可以把運算子看成乙個函式名,通過函式過載的方式為同乙個運算子實現不同規則的運算。所以運算子過載的本質就是函式過載,兩者唯一區別就是函式名,運算子過載的函式名由關鍵字operator和其後要過載的運算子符號構成,在形式上比普通函式名複雜。

運算子函式定義的一般格式如下:

資料型別 operator《運算子符號》(《參數列》)

2、運算子過載的規則

除了物件訪問成員『.』,成員指標運算子'.*'、作用域運算子'::'、「sizeof」運算子和三目運算子「?」之外,c++中所有自帶運算子都可以過載,但是合法的運算子過載還有以下4個規則:

(1)過載之後的運算子不能改變運算子的優先順序和結合性;

(2) 過載之後的運算子不能改變運算子運算元的個數和語法結構;

(3)過載的運算子至少有乙個自定義型別的;

(4)過載的運算子函式不能有預設的引數;

3、運算子過載的實現形式

(1)過載為類的成員函式;

(2)過載為類的非成員函式,非成員函式通常是友元;

4、舉例說明成員函式和友元函式的過載形式

(1)   成員函式運算子:

《函式型別》 operator 《運算子》(《參數列》)

呼叫方式:《物件名》.operator《運算子》(《參數列》)    

(2)友元函式運算子:

friend《函式型別》operator《運算子》(《參數列》)

呼叫方式:opeartor《運算子》(《引數一》,《引數二》)

5、兩種過載方式的比較

在多數情況下,將運算子過載為類的成員函式和類的友元函式都可以,但有些場合只能使用成員函式的形式,如 =、()、【】、->不能過載為類的友元函式,只能過載為成員函式形式。

6、運算子過載舉例

此處例舉的是四則運算符過載

#include <iostream.h>

class complex

complex(double r, double i)

complex operator +(const complex &c);

complex operator -(const complex &c);

complex operator *(const complex &c);

complex operator /(const complex &c);

friend void print(const complex &c);

private:

double real, imag;};

inline complex complex::operator +(const complex &c)

inline complex complex::operator -(const complex &c)

inline complex complex::operator *(const complex &c)

inline complex complex::operator /(const complex &c)

void print(const complex &c)

void main()

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

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

C 運算子過載賦值運算子

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

C 運算子過載轉換運算子

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