4.5 运算符重载
运算符重载概念:对已有的运算符进行重新定义,赋予其另一种功能,以适应不同的数据类型
4.5.1 加号运算符重载
作用:实现两个自定义数据类型相加的运算

运算符重载也可以发生函数重载
总结1:对于内置的数据类型的表达式的运算符是不能改变的
总结2:不要滥用运算符重载
4.5.2 左移运算符重载
作用:可以输出自定义数据类型
利用成员函数重载 左移运算符 p.operator<<(cout) 简化版本 p<<cout
故若利用成员函数重载<<运算符,无法实现cout在左侧
只能利用全局函数重载左移运算符
ostream对象只能有一个
// 本质 operator<<(cout, p) 简化 cout << p
ostream& operator<<(ostream &cout, Person &p)
{
cout << "m_A = " << p.m_A << "m_B = " << p.m_B;
}
总结:重载左移运算符配合友元可以实现输出自定义数据类型
4.5.3 递增运算符重载
作用:通过重载递增运算符,实现自己的整形数据
// 重置前置++运算符,返回引用为了一直对一个数据进行递增操作
MyInteger& operator++()
{
// 先进行++运算
m_Num++;
// 再将自身做返回
return *this;
}
//重置后置++运算符
//void operator++(int),int 代表占位参数,可以用于区分前置和后置递增
MyInteger operator++(int)
{
//先记录当时的结果
MyInteger temp = *this;
//后递增
m_Num++;
//最后将记录结果做返回
return temp;
//由于返回的是局部变量,所以后置递增不能返回引用
}
4.5.4 赋值运算符重载
C++编译器至少给一个类添加4个函数
- 默认构造函数(无参,函数体为空)
- 默认析构函数(无参,函数体为空)
- 默认拷贝构造函数,对属性进行值拷贝
- 赋值运算符 operator=,对属性进行值拷贝
如果类中有属性有指向堆区,做赋值操作时也会出现深浅拷贝的问题


//重载 赋值运算符
Person& operator=(Person &p)
{
//编译器是提供浅拷贝
//m_Age = p.m_Age;
//应该先判断是否有属性在堆区,如果有先释放干净,然后再深拷贝
if(m_Age != NULL)
{
delete m_Age;
m_Age = NULL;
}
//深拷贝
m_Age = new int(*p.m_Age)
//返回对象本身
return *this;
}
4.5.5 关系运算符重载
作用:重载关系运算符,可以让两个自定义类型对象进行对比操作
4.5.6 函数调用运算符重载
- 函数调用运算符()也可以重载
- 由于重载后使用的方式非常像函数的调用,因此称为仿函数
- 仿函数没有固定写法,非常灵活
匿名函数对象:当前行运行完后,立即被释放。
本文详细介绍了C++中运算符重载的各个方面,包括加号、左移、递增、赋值、关系运算符以及函数调用运算符的重载技巧,以及注意事项。通过实例演示了如何利用友元和成员函数实现自定义数据类型的操作,并探讨了合理使用运算符重载的重要性。
1199

被折叠的 条评论
为什么被折叠?



