c++之递增运算符重载
时间:2022-07-23
本文章向大家介绍c++之递增运算符重载,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
#include<iostream>
using namespace std;
class MyInteger {
friend ostream& operator<<(ostream& cout, MyInteger myInteger);
public:
MyInteger() {
num = 0;
}
//重载++i运算符
//返回引用是为了对同一个数据进行递增操作
MyInteger & operator++() {
num++;
return *this;
}
//重载i++运算符,int是占位符,后置递增要返回值
MyInteger operator++(int) {
//先记录当时结果
MyInteger tmp = *this;
//后递增
num++;
//再返回记录的结果
return tmp;
}
private:
int num;
};
ostream & operator<<(ostream &cout,MyInteger myInteger) {
cout << "num=" << myInteger.num;
return cout;
}
void test() {
MyInteger myInteger;
cout << ++(++myInteger)<<endl;
cout << myInteger << endl;
}
void test2() {
MyInteger myInteger;
cout << myInteger++ << endl;
cout << myInteger << endl;
}
int main() {
test2();
system("pause");
return 0;
}
说明:
1.如果
MyInteger & operator++() {
num++;
return *this;
}
这里返回的是MyInteger而不是引用MyInteger &,在调用test()时,会输出:
也就是没有达到++i类似的效果:先计算,后赋值。这是因为,当执行一遍++MyInteger后,再执行++(++MyInteger) ,此时这里的(++MyInteger)已经不再是原来的MyInteger对象了,所以++(++MyInteger) 的结果是2,而MyInteger的结果是1,因此采用&,操作的就是同一个对象。这之后再调用test(),输出为:
要想实现另外一种自增,即i++,先赋值,后计算,就需要重载自增函数,只需要向重载函数中传入int占位符即可。同时,在函数里面,先要记录当前的值,再进行++,最后返回原先记录的值,这里返回的不能是引用,因为假设我们返回的是引用,相当于返回的是tmp的引用,而tmp是一个局部变量,在函数运行完后就会释放,此时再去访问该地址,就不合法了。最后调用test2(),输出为:
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法