對已有的運算子進行重新定義,賦予其另外一種功能,已適應不同的資料型別
利用類內函式過載
#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...