運算子過載

2021-10-04 21:34:27 字數 3245 閱讀 4377

對已有的運算子進行重新定義,賦予其另外一種功能,已適應不同的資料型別

利用類內函式過載

#include

"stdafx.h"

#include

using

namespace std;

class

complex

complex

(double r,

double i)

//成員函式實現運算子過載

利用全域性函式過載

#include

"stdafx.h"

#include

using

namespace std;

class

complex

complex

(double r,

double i)

void

display()

;public

:double real;

double imag;};

//類外要引用屬性,因此將其設定為共有

complex operator

+(complex &c1,complex &c2)

void complex::

display()

void

test01()

intmain()

關鍵點在於兩個地方

1.不能用成員函式過載;

2.注意返回值的型別,要不然沒辦法實現鏈式程式設計;

用空型別返回時

class

person

//成員函式實現不了過載,相當於p.operator<

//相當於p/ void operator<

// private

:int m_age;

int m_height;};

//通過全域性函式,配合友元,可以實現過載,注意返回值

void

operator

<<

(ostream &out, person &p)

void

test01()

intmain()

上面函式用空型別返回,但是如果將test01改為

則會編譯不通過,因為過載的返回值型別為空,沒辦法實現鏈式輸出;

正確**如下,注意過載時返回值型別的區別的區別:

class

person

//成員函式實現不了過載 p/ void operator<

// private

:int m_age;

int m_height;};

//通過全域性函式,配合友元,可以實現過載,注意返回值

//ostream物件只能有乙個

ostream&

operator

<<

(ostream &out, person &p)

void

test01()

intmain()

前置++用引用,後置值傳遞

class

time

time

(int m,

int s)

time&

operator++(

);//定義前置自增運算子++

time operator++(

int)

;//定義後置自增運算子++

private

:int minute;

int sec;};

//通過全域性函式,配合友元,可以實現過載,注意返回值

//ostream物件只能有乙個

如果類中有內容指向堆區,會出現深淺拷貝的現象

c++編譯器至少給乙個類新增四個函式

1、預設建構函式(無參、函式體為空)

2、預設析構函式(無參、函式體為空)

3、預設拷貝建構函式,對屬性進行值拷貝

4、賦值運算子operator=,對屬性進行值拷貝

後面兩種回出現深淺拷貝的問題,要注意

class

person

person&

operator

=(person &p)

~person()

cout <<

"析構函式"

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

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

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

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

運算子過載

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