L#R
成员函数形式:L.operator#(R)
全局函数形式:operator#(L,R)
#O
/O#
三目操作符无法重载
// 运算类双目操作符函数
#include
using namespace std;
class Human{
public:
Human(int age = 0, const char* name="匿名"):m_age(age),m_name(name){
// [int m_age = age;]
// [string m_name(name);]
}
void getInfo(){
cout << "姓名:" << m_name << ", 年龄:" << m_age << endl;
}
// 成员形式操作符函数
// Human operator+(const Human& r) const {
// return Human(this->m_age+r.m_age, (this->m_name+"+"+r.m_name).c_str());
// }
private:
int m_age;
string m_name;
friend Human operator+(const Human& l,const Human& r); // 友元声明
};
// 全局形式操作符函数
Human operator+(const Human& l, const Human& r){
return Human(l.m_age+r.m_age, (l.m_name+"+"+r.m_name).c_str());
}
int main(void){
Human a(22,"张飞"), b(20,"赵云"); // 非常左值
const Human c(25,"关羽"), d(32,"马超"); // 常左值
Human res = a + b; // ==> a.operator+(b) 或 operator+(a,b)
res.getInfo();
res = c + d; // ==> c.operator+(d) 或 operator+(c,d)
res.getInfo();
res = Human(45,"黄忠") + Human(35,"刘备"); // ==> Human(45,"黄忠").operator+(Human(35,"刘备")) 或
// operator+(Human(45,"黄忠"),Human(35,"刘备"))
res.getInfo();
return 0;
}
// 赋值类双目操作符函数
#include
using namespace std;
class Human{
public:
Human(int age = 0, const char* name="匿名"):m_age(age),m_name(name){
// [int m_age = age;]
// [string m_name(name);]
}
void getInfo(){
cout << "姓名:" << m_name << ", 年龄:" << m_age << endl;
}
// 成员形式操作符函数
Human& operator+=(const Human& r){
this->m_age = this->m_age + r.m_age;
this->m_name = this->m_name + "+" + r.m_name;
return *this;
}
private:
int m_age;
string m_name;
friend Human operator+(const Human& l,const Human& r); // 友元声明
};
全局形式操作符函数
//Human& operator+(Human& l, const Human& r){
// l->m_age = l->m_age + r.m_age;
// l->m_name = l->m_name + "+" + r.m_name;
// return *l;
//}
int main(void){
Human a(22,"张飞"), b(20,"赵云"); // 非常左值
const Human c(25,"关羽"), d(32,"马超"); // 常左值
((a+=b)+=c)+=Human(45,"黄忠");
a.getInfo();
return 0;
}
// 比较类双目操作符函数
#include
using namespace std;
class Human{
public:
Human(int age = 0, const char* name="匿名"):m_age(age),m_name(name){
// [int m_age = age;]
// [string m_name(name);]
}
void getInfo(){
cout << "姓名:" << m_name << ", 年龄:" << m_age << endl;
}
// // 成员形式操作符函数
// bool operator==(/*const Human* this */ const Human& that)const{
// return this->m_age==that.m_age && this->m_name==that.m_name;
// }
// bool operator!=(/*const Human* this */ const Human& that)const{
return this->m_age!=that.m_age || this->m_name!=that.m_name;
// return !(*this==that);//使用operator==
// }
private:
int m_age;
string m_name;
friend bool operator==(const Human& l, const Human& r); // 友元声明
friend bool operator!=(const Human& l, const Human& r); // 友元声明
};
// 全局形式操作符函数
bool operator==(const Human& l, const Human& r){
return l.m_age==r.m_age && l.m_name==r.m_name;
}
bool operator!=(const Human& l, const Human& r){
// return l.m_age!=r.m_age || l.m_name!=r.m_name;
return !(l==r);//使用operator==
}
int main(void){
Human a(22,"张飞"), b(20,"赵云"); // 非常左值
const Human c(25,"关羽"), d(32,"马超"); // 常左值
cout << (a == b) << endl; //0 ==> a.operator==(b) 或者 ...
cout << (a != b) << endl; //1 ==> a.operator!=(b) 或者 ...
cout << (c == d) << endl; //0 ==> c.operator==(d) 或者 ...
cout << (c != d) << endl; //1 ==> c.operator!=(d) 或者 ...
cout << (Human(45,"黄忠") == Human(35,"刘备")) << endl; //0 ==> Human(45,"黄忠").operator==(Human(35,"刘备")) 或者 ...
cout << (Human(45,"黄忠") != Human(35,"刘备")) << endl; //1 ==> Human(45,"黄忠").operator!=(Human(35,"刘备")) 或者 ...
return 0;
}
// 运算类单目操作符函数
#include
using namespace std;
class Human{
public:
Human(int age = 0, const char* name="匿名"):m_age(age),m_name(name){
// [int m_age = age;]
// [string m_name(name);]
}
void getInfo(){
cout << "姓名:" << m_name << ", 年龄:" << m_age << endl;
}
// 成员形式操作符函数
Human operator-(/* const Human* this */)const{
return Human(-this->m_age,("-"+this->m_name).c_str());
}
private:
int m_age;
string m_name;
// friend Human operator-(const Human& l); // 友元声明
};
//Human operator-(const Human& l){
// return Human(-l.m_age,("-"+l.m_name).c_str());
//}
int main(void){
Human a(22,"张飞"), b(20,"赵云"); // 非常左值
const Human c(25,"关羽"), d(32,"马超"); // 常左值
Human res = -a; // ==> a.operator-() 或 ...
res.getInfo();//姓名:-张飞, 年龄:-22
res = -c; // ==> c.operator-() 或 ...
res.getInfo();//姓名:-关羽, 年龄:-25
res = -Human(45,"黄忠"); // ==> Human(45,"黄忠").operator-() 或 ...
res.getInfo();//姓名:-黄忠, 年龄:-45
return 0;
}
// 自增减类单目操作符函数
#include
using namespace std;
class Human{
public:
Human(int age = 0, const char* name="匿名"):m_age(age),m_name(name){
// [int m_age = age;]
// [string m_name(name);]
}
void getInfo(){
cout << "姓名:" << m_name << ", 年龄:" << m_age << endl;
}
//成员形式操作符函数
// // 前++ ++a
// Human& operator++(/* Human* this */){
// this->m_age+=1; // 直接加1
// this->m_name+="a"; // 直接加
// return *this;
// }
后++ a++
// Human operator++(/* Human* this */int){
// Human old = *this; // 备份原来的值
// this->m_age+=1; // 直接加1
// this->m_name+="a"; // 直接加
// return old; // 返回原来的值
// }
private:
int m_age;
string m_name;
friend Human& operator++(Human& l); // 友元声明
friend Human operator++(Human& l,int); // 友元声明
};
// 前++ ++a
Human& operator++(Human& l){
l.m_age+=1; // 直接加1
l.m_name+="a"; // 直接加
return l;
}
// 后++ a++
Human operator++(Human& l,int){
Human old = l; // 备份原来的值
l.m_age+=1; // 直接加1
l.m_name+="a"; // 直接加
return old; // 返回原来的值
}
int main(void){
Human a(22,"张飞"), b(20,"赵云"); // 非常左值
const Human c(25,"关羽"), d(32,"马超"); // 常左值
//姓名:张飞a, 年龄:23
(++a).getInfo(); // a.operator++() 或 ...
//姓名:赵云, 年龄:20
(/*|...|*/b++).getInfo(); // b.operator++(0) 或 ...
//姓名:赵云a, 年龄:21
b.getInfo();
return 0;
}
ostream& operator< < (ostream& os, const RIGHT& right) { ...}
// 输入/输出流操作符函数
#include
using namespace std;
class Human{
public:
Human(int age = 0, const char* name="匿名"):m_age(age),m_name(name){
// [int m_age = age;]
// [string m_name(name);]
}
/* void getInfo(){
cout << "姓名:" << m_name << ", 年龄:" << m_age << endl;
}*/
// 成员形式操作符函数
private:
int m_age;
string m_name;
friend ostream& operator<<(ostream& os, const Human& that);
friend istream& operator>>(istream& is, Human& that);
};
// 全局形式操作符函数
ostream& operator<<(ostream& os, const Human& that){
os << "姓名:" << that.m_name << ", 年龄:" << that.m_age;
return os;
}
//istream& operator>>(istream& is, Human& that){
// is >> that.m_name >> that.m_age;
// return is;
//}
int main(void){
Human a(22,"张飞"); // 非常左值
const Human b(20,"赵云"); // 常左值
cout << a << endl; // cout.operator<<(a) 或 operator<<(cout,a)
cout << b << endl; // cout.operator<<(b) 或 operator<<(cout,b)
cout << Human(45,"黄忠") << endl; // cout.operator<<(Human(45,"黄忠")) 或 operator<<(cout,Human(45,"黄忠"))
// cin >> a; // cin.operator>>(a) 或 operator>>(cin,a)
cout << a << endl;
return 0;
}
istream& operator>> (istream& is, RIGHT& right) { ...}
// 输入/输出流操作符函数
#include
using namespace std;
class Human{
public:
Human(int age = 0, const char* name="匿名"):m_age(age),m_name(name){
// [int m_age = age;]
// [string m_name(name);]
}
/* void getInfo(){
cout << "姓名:" << m_name << ", 年龄:" << m_age << endl;
}*/
// 成员形式操作符函数
private:
int m_age;
string m_name;
friend ostream& operator<<(ostream& os, const Human& that);
friend istream& operator>>(istream& is, Human& that);
};
// 全局形式操作符函数
ostream& operator<<(ostream& os, const Human& that){
os << "姓名:" << that.m_name << ", 年龄:" << that.m_age;
return os;
}
istream& operator>>(istream& is, Human& that){
is >> that.m_name >> that.m_age;
return is;
}
int main(void){
Human a(22,"张飞"); // 非常左值
cin >> a; // cin.operator>>(a) 或 operator>>(cin,a)
cout << a << endl;
return 0;
}
若源类型是基本类型,目标类型是类类型,则只能通过类型转换构造函数实现自定义类型转换
class 目标类型{
目标类型(const 源类型& src){ ... }
}
若源类型是类类型,目标类型是基本类型,则只能通过类型转换操作符函数 实现自定义类型转换
class 源类型{
operator 目标类型(void) const { ...}
}
若源类型和目标类型都是类类型 (而非基本类型) ,则既可以通过类型转换构造函数也可以通过类型转换操作符函数实现自定义类型转换,但不要两者同时使用
若源类型和目标类型都是基本类型,则无法实现自定义类型转换,基本类型间的类型转换规则完全由编译器内置
// 类型转换构造函数和类型转换操作符函数
#include
using namespace std;
class Integer{
public:
Integer(int i):m_i(i){
//【int m_i = i;】
cout << "Integer类的类型转换构造函数被调用" << endl;
}
operator int(/* const Integer* this */)const{
cout << "Integer类的类型转换操作符函数被调用" << endl;
return this->m_i;
}
private:
int m_i;
};
int main(void){
int n = 666;
// int --> Integer(基本类型-->类类型)
Integer ix = n; // 定义匿名Integer对象,利用匿名Integer对象.Integer(n) --> 触发类型转换构造函数
// Integer ix = n.operator Integer() --> int类中没有一个operator Integer(走不通)
// Integer --> int(类类型 --> 基本类型)
int m = ix; // 定义匿名int对象,利用匿名int对象.int(ix)-->int类中没有一个形参是Integer类型的构造函数(走不通)
// int m = ix.operator int() --> 触发类型转换操作符函数
return 0;
}
// 类型转换构造函数和类型转换操作符函数
#include
using namespace std;
class Dog; // 短式声明/前置声明
class Cat{
public:
Cat(const char* name):m_name(name){
// [string m_name(name);]
}
void talk() {
cout << m_name << ": 喵喵~~~" << endl;
}
operator Dog(/* const Cat* this */)const; // 声明
private:
string m_name;
friend class Dog; // 友元声明
};
class Dog{
public:
Dog(const char* name):m_name(name){
// [string m_name=name;]
}
/* Dog(const Cat& that):m_name(that.m_name){ // 类型转换构造(定制了Cat-->Dog的转换规则)
//【string m_name = that.m_name;】
cout << "Dog类的类型转换构造函数被调用" << endl;
}*/
void talk() {
cout << m_name << ": 汪汪~~~" << endl;
}
private:
string m_name;
};
Cat::operator Dog(/* const Cat* this */)const{ // 定义
cout << "Cat类的类型转换操作符函数被调用" << endl;
return Dog(this->m_name.c_str());
}
int main( void ) {
Cat smallwhite("小白");
Dog bigyellow = smallwhite; // 定义匿名Dog类对象,利用匿名Dog类对象.Dog(smallwhite)-->触发Dog类的类型转换构造函数
// Dog bigyellow = smallwhite.operator Dog() --> 触发Cat类的类型转换操作符函数
return 0;
}
不是所有的操作符都能重载,以下操作符不能重载
::
).
)?:
)sizeof
)typeid
)无法重载所有操作数均为基本类型的操作符: 如实现 1+1=3