首先从左移运算符(<<)开始迷糊,然后迷迷糊糊听到了递增运算符(++)一直有几个问题让我停滞不前,问题如下:
1.左移运算符中的返回ostream引用问题,以及重载左移运算符函数中的形参问题
2.this指针的相关问题,这里主要是:为什么递增运算符返回的是*this,这个*this是什么东西
3.下面的函数中那么多 << 什么时候才会调用这个重载后的 << 呢(可以和1联系的看)
下面附上代码:
#include<iostream>
using namespace std;
class myinteger
{
friend ostream& operator<<(ostream& cout, myinteger myint);
public:
myinteger()
{
m_num = 0;
}
//重载前置++运算符
myinteger& operator++() //如果不加引用这里返回的就是该对象的拷贝,相当于创建了一个新对象,无法实现 ++(++a)
{
m_num++;
return *this; //把自身做一个返回
}
//重载后置运算符
myinteger operator++(int) //这个int代表占位参数,可以用于区分前置和后置递增
{
//先 记录当时结果
myinteger temp = *this; //这里的temp是临时对象,所以最后返回值类型不能写引用
//后 递增
m_num++;
//最后将记录结果返回
return temp;
}
public:
int m_num;
};
//重载左移运算符
ostream& operator<<(ostream& out, myinteger myint)
{
out << myint.m_num;
return out;
}
void test01()
{
myinteger myint;
cout <<endl;
cout << ++myint<< endl;
}
void test02()
{
myinteger myint;
cout << myint++ << endl;
cout << myint << endl;
}
int main()
{
test01();
//test02();
return 0;
}
上面是重载递增运算符(++)的代码,在一步步实现重载++的过程中首先出现的是下面这个代码<<无法识别 myint,即编译系统不知道 输出myint该输出些什么,然后现在要做的就是重载<<
cout << myint<< endl;
//对应上面代码中的 cout << ++myint<< endl;
在重载 << 时就碰到了之前没解决的疑惑:下面测试函数test01中那么多左移运算符,什么时候才会调用这个重载后的 << 呢!然后通过下面的图片疑惑得到解答
带阴影的<<就是运用到重载的地方!他们都有一个共同点,就是后面都有 myinteger类的对象存在。所以这些重载函数的调用时机就是 下面的数据类型和形参匹配的时候。以往的普通函数调用时,虽然也匹配形参,但是不会把参数左边放一个右边放一个,这就是左移运算符特殊的地方。
而没有运用到<<重载的地方都是咱们平常所见的<<的含义。
另外需要强调一下左移运算符重载函数中 下面这行代码中 <<的含义
out << myint.m_num;
重载函数的函数体,其中的代码都是我们编译器可以直接识别的代码,他就是用编译器能直接识别的代码组合然后实现一个新的功能。所以上代码中的<<就是我们最基本的<<含义,和重载的<<没任何关系(除了长得一样)。此外这里的out因为是cout的引用,所以可以实现cout的相同功能!
然后左移运算符重载的问题解决后就到了递增(++)的重载了
由于基础不扎实,忘掉了this指针的相关知识:
return *this返回当前对象, return this返回当前对象的地址(指向当前对象的指针)。
这个很关键!!!!
然后返回了*this就可以实现下面代码的链式运用 如果返回的是知识一个void 那么第一次 ++myint可以实现,但是如果写成 ++(++myint) 就不对了。
同时要注意得用 myinteger& 来接收*this(即返回的对象本身),如果不用引用接收,这里函数最后接收到的就是对象本身的拷贝,并非对象本身(详细可以看看小破站黑马程序员的拷贝构造部分),依然无法实现对 ++(++myint)的成功实现。所以一定要用引用接收!!!