递增运算符++
先看一下它的内置运算原理
int a=10;
cout<<++a<<endl//结果11
cout<<a<<endl//11
int b=10;
cout<<b++<<endl;//10
cout<<b<<endl;//11
先建立一个类
class MyInteger{
public:
MyInteger(){
m_Num=0;
}
private:
int m_Num;
}
分为两部分
前置递增和后置递增
前置递增
#include<iostream>
#include<string>
using namespace std;
//通过全局函数重载
class MyInteger {
friend ostream&operator<<(ostream &cout, MyInteger&m);
public:
MyInteger() {
m_Num = 0;
}
//重载前置++运算符
MyInteger& operator++() {
m_Num++;
return *this;
}
//为什么要返回引用,为了一直对一个数据进行递增操作
//如果是去掉引用,相当于重新建立了另一个一样的对象,并对其进行操作。那么你
//每使用一次这个对象变量的值不是连续递增操作的值。
//而且,去了引用也会不报错
//还需要重载左移运算符
ostream&operator<<(ostream &cout, MyInteger&m) {
cout << m.m_Num;
return cout;
}
void test01() {
MyInteger myint;
cout << ++myint<< endl;
}
int main() {
test01();
return 0;
}
后置递增
#include<iostream>
#include<string>
using namespace std;
//通过全局函数重载
class MyInteger {
friend ostream&operator<<(ostream &cout, MyInteger m);
public:
MyInteger() {
m_Num = 0;
}
//重载前置++运算符
MyInteger &operator++() {//为什么要返回引用,为了一直对一个数据进行递增操作
//如果是去掉引用,相当于重新建立了另一个一样的对象,并对其进行操作。那么你
//每使用一次这个对象变量的值不是连续递增操作的值。
m_Num++;
return *this;
}
//重载后置++运算符
//int代表占位参数,可以用于区别前置和后置递增
MyInteger operator++(int) {//后置必须返回值,不能返回引用,因为你return 后面返回的是局部变量
//先记录当时结果
MyInteger temp = *this;
//后递增
m_Num++;
//返回记录结果
return temp;
}
private:
int m_Num;
};
//还需要重载左移运算符
ostream & operator<<(ostream &cout, MyInteger m) {
cout << m.m_Num;
return cout;
}
void test01() {
MyInteger myint;
//cout << myint << endl << myint++ << endl << myint << endl << myint++ << endl;
cout << myint++ <<endl;
cout << myint <<endl;
}
int main() {
test01();
return 0;
}
其中int的作用是占位符,为了和前置递增区分开来,而且只能写int,写double、float等都是不行的。因为没有这个占位参数的话,该函数与前置递增就只有返回值不同了,而返回值是不可以作为函数重载的条件的。
新发现:
若最后结果这样输出,可以看到结果是
我当时很不可思议 为什么不是 0 0 1 1 2呢
其实我最早用的示例是这个示例
void test01() {
MyInteger myint;
//cout << myint << endl << myint++ << endl << myint << endl << myint++ << endl;
//cout << myint++ << endl;
cout << myint++ << endl << myint << endl<<myint<<endl;
cout << myint <<endl;
}
疑问,为什么结果是这样的呢,为什么不应该是0 1 1 1呢
我甚至还求了这每个cout的地址,这个是一个值
还有每个myint的地址发现他们 ,发现&(myint)不一样之外别的都是一个地址
然后,我觉得是cout函数的问题,它的输出顺序有问题
原来是它从右往左扫描然后从左往右输出
而且还应该这么理解,从右往左扫描之后,一旦遇到子函数,就立即计算出结果,然后结果在数据缓存区的位置是与cout<<代码从左往右的顺序相对应的,比如说最右边的从左数是第四个,那么结果也排在从左数第四个,也就是说计算执行顺序从右往左,那么第一个的第一个cout从右往左的执行结果在数据区的位置排序应该是2 1 1 0,(按照结果得出的顺序是0 1 1 2),然后输出为2 1 1 0 然后下一个cout的结果为2
下一个是 0 0 0 然后第二个cout输出为1