運算子過載:是把運算子的運算元擴充套件到類物件上
運算子過載有兩種形式:
成員函式形式、普通函式形式
成員函式形式一般般語法形式:
返回型別 operator 運算子(形參表)
string& operator=(const string& ref)
{}普通函式形式:
int operator+(const int& a, const int& b)
例:string類運算元的過載
#include#includeusing namespace std;
class string
~string()
string(const string& ref)
:ps(new char[strlen(ref.ps) + 1])
//賦值過載
string& operator=(const string& ref)
this->ps = new char[strlen(ref.ps) + 1];
strcpy(this->ps, ref.ps);
return *this;
} //+過載
string & operator+(string &ref)
//+=過載
string & operator+=(string &ref)
//==過載
bool operator==(const string&ref)
//>=
bool operator>=(const string&ref)
//char& string::operator(int index)
public:
void show()const };
int main()
運算子過載需要注意以下幾點:
只能過載已有的運算子,不能創造新的運算子.
「.」, 「.*」, 「::」, "?:"不能過載.
過載運算子時,如果其所有運算元都是內建型別,則不能過載.
「=」,"","->","()"只能以成員形式過載.
過載運算子不會改變運算子三特性.
單目運算子:
a.成員形式,無參,唯一運算元傳給this.
b.普通函式,單參,唯一運算元傳給引數.
雙目運算子:
a.成員形式,單參,左運算元傳給this,右運算元傳給引數.
b.普通函式,雙參,左運算元傳給第一引數, 右運算元傳給第二引數.
7*. 過載運算子盡可能保證所作操作和原運算子功能一致或相近 (建議)
運算子過載之過載型別運算子
普通型別 類型別 呼叫對應的只有乙個引數 引數的型別就是這個普通型別 的建構函式 需求 boy boy1 10000 薪資 建構函式boy int boy boy2 rock 姓名 建構函式boy char 普通型別賦值給類型別其實很簡單,就是專門的對這個賦值的型別定義乙個建構函式。編譯器在執行 的...
運算子過載 賦值運算子的過載
有時候希望賦值運算子兩邊的型別可以不匹配,比如,把乙個int型別變數賦值給乙個complex物件,或把乙個 char 型別的字串賦值給乙個字串物件,此時就需要過載賦值運算子 注意 賦值運算子 只能過載為成員函式 賦值運算子過載例項示例 include include using namespace ...
運算子過載
c 中的運算子 1。大多數系統預定義運算子都能過載 不值得過載 不能被過載 2過載不能改變優先順序 不能改變結合性 不能改變運算子所需運算元的個數 過載後,可按這些運算子的表達方式使用 運算子過載的語法 一 通過運算子過載函式進行過載 1。運算子過載函式是成員函式 語法形式 type x opera...