C 運算子過載

2021-06-18 22:12:02 字數 1890 閱讀 3495

將現在的操作符與乙個成員函式相關聯並將該操作與其類的物件(作為它的運算元)一起使用,稱為操作符過載。過載運算子用operator關鍵字來完成。

操作符函式的格式如下:

operator op(argument-list)

其中,op是將要過載的操作符,例如,operator+()過載+操作符。operator *()過載*操作符。op必須是有效的c++操作符,不能虛構乙個新的符號。

1,過載運算子其實就是過載函式,它的優先順序和結合性是不能被更改,但是引數和返回值都是可以更改的。

2, c++規定  .  ->   ::   *    ?: 這五個運算子不能過載, .成員運算子。 ->指標成員運算子。 *間接運算子。?:條件去處符。

也不能創造新的運算子。

3,在過載運算時,應保持過載生的運算意義與原行的運算相一致,不允許出現改變原先運算子意義的過載。

三目運算子不能過載

單目運算子過載。

openater++()//前置方法

openater++(int)//後置方法。int是說明符,並不是資料型別。。單目運算子是沒有引數的。

#include 

class cpoint

void setpoint(int _nx,int _ny)

int getpointx()

int getpointy()

cpoint

operator

+(cpoint&_obj)

void show()

}; int main(int argc, const

char * argv)

《用普通函式的形式過載運算子》

#include 

class cpoint

void setpoint(int _nx,int _ny)

void show()

};std::ostream& operator

<<(std::ostream& _out,cpoint& _obj)

std::istream& operator>>(std::istream& _in,cpoint& _obj)

int main(int argc, const

char * argv)

單目運算子過載。

openater++()//前置方法

openater++(int)//後置方法。int是說明符,並不是資料型別。。單目運算子是沒有引數的。

#include 

class clock

void showtime()const;

voidoperator++();

voidoperator++(int);

};void

clock

::operator++()

}std

::cout

<<"++clock:";

}void

clock

::operator++(int)

}std

::cout

<<"clock++:";

}void

clock::showtime()const

int main(int argc, const

char * argv)

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

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

C 運算子過載賦值運算子

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

C 運算子過載轉換運算子

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