# c++运算符重载之 前置++, 后置++, 负号运算符, 类型转换函数, 以及输入输出运算符

时间:2022-11-07 21:46:22

c++运算符重载之 前置++, 后置++, 负号运算符, 类型转换函数, 以及输入输出运算符

标签(空格分隔): c++


前言

我在c++学习的过程中, 对这几个不太常见的运算符重载不太会写。出现了很多bug,而且搜索网上东西也比较少,所以特地写这一篇来分享给大家,同时加深印象。有出错的地方希望给位朋友斧正。


先看例子, 我定义一个类 Int 和我们基础的c++ int是一个意思

using  namespace std;
#include <iostream>
class Int
{
int data;
public:
Int &operator++(); //前置++
operator int(); //转换运算符
Int operator++(int) ; //后置++
Int &operator--() ; //前置--
Int operator--(int) ; //后置--
Int operator-() ; //负号运算符
friend ostream & operator<<(ostream &out, Int& a) ; //输出运算符号
friend istream & operator >> (istream &in, Int& a) ; //输入运算符号 };

1.前置与后置++ 前置–和后置–

首先明确的是咱们c和c++ 的前置++和后置++ 都是重载的++ 那他们的重载怎么写呢?

    Int& Int::operator++() {         //前置++
this->data++;
return *this;
} Int Int::operator++(int) { //后置++
Int tmp(*this);
this->data++;
return tmp;
} Int& Int::operator--() { //前置--
this->data--;
return *this;
} Int Int::operator--(int) { //后置--
Int temp(*this);
this->data--;
return temp;
}

Int& Int::operator++() //前置++

Int Int::operator++(int) //后置++

细心的朋友已经发现了 关键在于后置的重载++ 首先返回的是Int而不是 对象的引用, 然后在最后面(int)加了int参数 。 第一个问题好解决,因为我后置++函数返回的是tmp这个临时对象,在函数结束后被释放了,所以当然不能传引用啦, 对于第二个问题,这个是c++的规定。好吧我也很无语。只要在重载操作符的参数中加上一个int型参数,记住你改成double 都会错的。

前置–和后置–原理与前面相同,代码相似,不予复述。

2类型转换函数

转化运算符, 就是把类的对象转化成其他(基本类型,或其他类型)

    Int::operator int() {           //转换运算符
return data;
}

函数形式里不能有返回值,不能有参数,只能返回要转换的数据类型。 这里int是我要转化的类型所以我括号前是写int 返回的也是int 类型。

用于处理这样的问题

int c = 0;
Int c1(2);
c = c1; //这时 c1调用类型转换函数 对象c1返回了int 赋给变量c

3负号重载

    Int Int::operator-() {     //负号运算符
Int tmp;
tmp.data = -data;
return tmp;
}

函数形式里,不能有参数,返回对象(不能是引用原因和后置++相同)。

记住要用一个临时的tmp来储存变负的对象属性值,返回tmp

下面是错误的写法:

    Int Int::operator-() {     //负号运算符
data = -data;
}

重载-号的意思不是直接改变对象的符号,是返回一个符号相反的对象,举个例子,-5不是说把5改成负数,是得到5的相反数,准确说,负号有两个重载,取反操作符和减号操作符,这个是前者


4输入输出重载

ostream & operator<<(ostream &out, Int& a) {          //输出运算符号
out << a.data;
return out;
} istream & operator >> (istream &in, Int& a) { //输入运算符号
in >> a.data;
return in;
}

提几个小问题吧, 首先所有参数都是引用不是对象(尤其是输入函数不传引用,输入函数不改变值) 然后要记得 istream是用在输入中 不要用反, 不要加作用域运算符。