1、 算術運算子過載(+ - * /)
friend const 類名 operator +(- * /)(const 類名& 物件名,const 類名& 另一物件名) ;
宣告部分:
friend const complex operator+(constcomplex& x, const complex& y);
實現部分:
constcomplex operator+(const complex& x,const complex& y);
2、 輸出運算子過載(《或》)
friend ostream& operator<<(ostream& out,const類名& 物件名);
宣告部分:
friend ostream& operator<<(ostream&out,const complex& x);
ostream& operator<<(ostream&out,const complex& x)//ostream
為乙個類,返回乙個物件的引用
3、下標運算子過載
const版本:const 類名/資料型別 &operator(int index)const;
非const版本:類名/資料型別 & operator(int index);
實現部分:
const int& operator[ ](int index) const
//const
版本的下標運算子
int& operator[ ](int index)//非
const
版本的下表運算子
4、賦值運算子過載(=)+=,-+,*=,/=
過載方式一樣
const 類名&operator=(const 類名& 物件名)
const account&account::operator=(const account &account)
//step 4。
return *this;//
第四,我們返回
*this
來實現函式鏈式呼叫
}
5、++和——運算子過載(前置和後置的區別)>,<,£,³運算子也是這樣來定義
前置:類名& operator++();
後置:const 類名 operator ++(int);
fraction& operator ++( ) //
前置++
,返回乙個引用
const fraction operator ++(int) //
後置++
,返回的是乙個值
6、相等運算子(==)
(friend)bool operator==(const 類名& 物件名,const類名& 另乙個物件名);
bool operator==(const vector& a, const vector& b)
return true;
}
7、拷貝建構函式
類名 (const 類名& 物件名);
vector(const vector &vector);//const
可以不加,但引用必須要加上。
運算子過載之過載型別運算子
普通型別 類型別 呼叫對應的只有乙個引數 引數的型別就是這個普通型別 的建構函式 需求 boy boy1 10000 薪資 建構函式boy int boy boy2 rock 姓名 建構函式boy char 普通型別賦值給類型別其實很簡單,就是專門的對這個賦值的型別定義乙個建構函式。編譯器在執行 的...
運算子過載 賦值運算子的過載
有時候希望賦值運算子兩邊的型別可以不匹配,比如,把乙個int型別變數賦值給乙個complex物件,或把乙個 char 型別的字串賦值給乙個字串物件,此時就需要過載賦值運算子 注意 賦值運算子 只能過載為成員函式 賦值運算子過載例項示例 include include using namespace ...
運算子過載
c 中的運算子 1。大多數系統預定義運算子都能過載 不值得過載 不能被過載 2過載不能改變優先順序 不能改變結合性 不能改變運算子所需運算元的個數 過載後,可按這些運算子的表達方式使用 運算子過載的語法 一 通過運算子過載函式進行過載 1。運算子過載函式是成員函式 語法形式 type x opera...