目录
对于自定义类型的运算往往需要借助函数来完成。当我们学习代码时会发现每个人都有自己代码命名风格,因此当我们阅读代码时会有一定的困难,使用起来也比较复杂。因此我们希望自定义类型也能想内置类型一样使用运算符。
那内置类型为什么可以直接使用运算符来进行比较呢?因为编译器知道它们之间的比较规则,可以将其转化为指令。
自定义类型之所以不能直接使用是因为每一个自定义类型的运算都是不一样的,编译器不知道这个自定义类型的规则是什么,不知道如何进行比较。
那如何使自定义类型也能使用运算符比较呢?
C++为了增强代码的可读性引入了运算符重载,运算符重载是具有特殊函数名的函数,也具有其 返回值类型,函数名字以及参数列表,其返回值类型与参数列表与普通的函数类似。
函数名字为:关键字operator后面接需要重载的运算符符号。
函数原型:返回值类型(根据需要的数据类型来定义) operator操作符(参数列表)
注意:
- 不能通过连接其他符号来创建新的操作符:比如operator@
- 重载操作符必须有一个类类型参数
- 用于内置类型的运算符,其含义不能改变,例如:内置的整型+,不能改变其含义
- 作为类成员函数重载时,其形参看起来比操作数数目少1,因为成员函数的第一个参数为隐藏的this
- .*? ::? sizeof? ?:? .??注意以上5个运算符不能重载。这个经常在笔试选择题中出现。
思路:看日期是否相等,就是看年月日是否都相等。
思路:如果年数值小,日期就小;当年数值相等时,月数值小,日期就小;当年月数值相等时,日数值小,日期就小。
?我们会发现 <=不就是 < 和 == 结果的结合,那我们可以使用前面定义的运算符重载吗?答案是可以的,在C++上被称为【复用】。?
?当我们想将一个数拷贝给另一个数时,也叫赋值。“=” 在C++里被称作赋值运算符。
参数类型:const T&,传递引用可以提高传参效率
返回值类型:T&,返回引用可以提高返回的效率,有返回值目的是为了支持连续赋值
检测是否自己给自己赋值
返回*this :要复合连续赋值的含义
?
当我们使用刚才的赋值运算符重载的函数连续赋值时,会发现报错。
分析:
①“d3=d1=d2”的意思是将d2的值赋值给d1,再将d1(d2)的值赋值给d3.所以当d2赋值给d1时,函数应该有返回值,返回值是d1.
②因为d1还需要赋值给d3,所以当“d1=d2”这个函数结束时,d1不能被销毁,所以函数是传引用传参。
this 是左操作数的地址,d是右操作数的别名。?
用户没有显式实现时,编译器会生成一个默认赋值运算符重载,以值的方式逐字节拷贝。
注 意:
内置类型成员变量是直接赋值的
自定义类型成员变量需要调用对应类的赋值运算符重载完成赋值。
既然编译器生成的默认赋值运算符重载函数已经可以完成字节序的值拷贝了,还需要自己实现吗?当然像日期类这样的类是没必要的,如果类中未涉及到资源管理,赋值运算符是否实现都可以;一旦涉及到资源管理则必须要实现。?
??前置++和后置++都是一元运算符,为了让前置++与后置++形成能正确重载,C++规定:后置++重载时多增加一个int类型的参数,但调用函数时该参数不用传递,编译器自动传递。
注意:后置++是先使用后+1,因此需要返回+1之前的旧值,故需在实现时需要先将this保存一份,然后给this + 1