为什么<<运算符的重载必须定义为友元
如果在类中定义非码友元成员函数,默认第一个参数默认会传入this*指针,这时就无法实现cout在前<<对象在后的格式
因为二元运算符中的调用格式是 参数一 运算符 参数二
这也就是为什么 加号运算符可以使用非友元成员函数,因为参数一是一个this*指针,参数二是其它对象
假设定义为非友元成员函数,那么第一个参数系统默认为this*(且无法更改),第二个参数是cout
那么调用格式就变成了 coor << cout了,这就是不能定义为非友元成员函数的原因
如果在类中定义非码友元成员函数,默认第一个参数默认会传入this*指针,这时就无法实现cout在前<<对象在后的格式
因为二元运算符中的调用格式是 参数一 运算符 参数二
这也就是为什么 加号运算符可以使用非友元成员函数,因为参数一是一个this*指针,参数二是其它对象
假设定义为非友元成员函数,那么第一个参数系统默认为this*(且无法更改),第二个参数是cout
那么调用格式就变成了 coor << cout了,这就是不能定义为非友元成员函数的原因
2017-04-16
operator定义了多个函数重载,定义了能传入一到两个参数的operator
为什么后置要传入int?
在一元operator中,运算符要放在参数前面,也就是operator++(*this),在程序中调用一元运算符的格式:
++coor,-coor
operator(int)其实是二元函数,只是第二个参数是通过隐性的方式传入参数,传入int就相当于定义了二元运算符,也就是(this*, int),这时运算符的格式就是this*指针加运算符加int类型,再给int传入一个默认值1
例如c++1,这就满足了运算符的格式,因此在使用时变成了c++,函数会执行,而内部如何处理,就由我们随便处理
为什么后置要传入int?
在一元operator中,运算符要放在参数前面,也就是operator++(*this),在程序中调用一元运算符的格式:
++coor,-coor
operator(int)其实是二元函数,只是第二个参数是通过隐性的方式传入参数,传入int就相当于定义了二元运算符,也就是(this*, int),这时运算符的格式就是this*指针加运算符加int类型,再给int传入一个默认值1
例如c++1,这就满足了运算符的格式,因此在使用时变成了c++,函数会执行,而内部如何处理,就由我们随便处理
2017-04-15