前置++,后置++

前置++,后置++

如有错误,欢迎指正。
如若转载,请声明原创:https://blog.youkuaiyun.com/qq_29567701/article/details/82732943

题目:

	int a = 4, b = 4, c = 4, d = 4;
	a += (a++);
	b += (++b);
	++c += c;
	++d += d++;

测试1:

	int a = 4, b = 4, c = 4, d = 4;
	a += (a++);
	b += (++b);
	++c += c;
	++d += d++;
	cout << a << " " << b << " " << c << " " << d << endl;//9 10 10 11
	

测试2:

	int a = 4, b = 4, c = 4, d = 4;
	cout << (a += (a++)) << endl;//8
	cout << (b += (++b)) << endl;//10
	cout << (++c += c) << endl;//10
	cout << (++d += d++) << endl;//10
	//后置运算符只有在该表达式运算结束之后,再次调用同名的变量时才会发挥它的威力

分析:

	int a = 4, b = 4, c = 4, d = 4;
	a += (a++);
	b += (++b);
	++c += c;
	++d += d++;

1、总体
在拥有 前置++、后置++、+(加法运算符) 的表达式中,
得按运算符的优先级来进行运算。
(a)前置++、后置++的优先级在Top2
(b)+(加法运算符)的优先级位于Top4
故先运算前置++,后置++(按出现的顺序从左向右依次运算),最后运算+(加法运算符)
2、代码
(1)a += (a++);
(1.1)先运算 后置++(Top2),即 a++,不过a++,是在该表达式执行完了时候才起作用的,故在该表达式中,a仍然为原数4,
(1.2)然后执行+(加法运算符)(Top4), a+=(a++),此时a=4+4=8(测试2); 过了该表达式后,再输出a,就是a=a+1=8+1=9(后置++起作用了)(测试1);
(2)b += (++b);
(2.1)先运算 前置++(Top2),即++b, 先+1,在参与后续该变量b的其它运算,此时,该表达式中所有变量b都等于5;
(2.2)然后执行+(加法运算符)(Top4),b += (++b);此时,b=5+5=10(测试2);
此表达式结束后,再次输出变量b,仍然是10(测试1),因为该表达式中没有用到后置++,故在该表达式结束后,变量b将不会再改变。
(3)++c += c;
分析同(2)b += (++b);
(3.1)先运算++c,得到该表达式中所有变量c都先自加1,然后再参与该表达式后续的运算,此时c=5;
(3.2)再运算+,即 ++c += c;,此时c=5+5=10;(测试2)
由于没有后置++,故此表达式结束之后,变量c仍然保持不变,c=10(测试1)
(4)++d += d++;
(4.1)同为Top2的 前置++,后置++都出现,按从左向右的顺序依次运算,
++d,此时d=5; 在运算d++, d++在此表达式结束后,到下一次调用变量d时才起作用,故此时,此表达式还没有运算完,故d仍然为5
(4.2)然后,运算+运算符。
即++d += d++; 此时,d=5+5=10;(测试2)
此表达式结束后,后置++起作用,当程序运行到下一次调用变量d时,d=d+1=10+1=11;(测试1)

**C语言运算符优先级:**来自百度百科
C语言运算符优先级

### 前置++ 后置++ 的区别 在 C++ 中,前置 `++` 运算符后置 `++` 运算符有着不同的行为。前置形式会先增加变量的值再返回新的值[^1],而后置形式则会在返回当前值后再执行加一操作。 #### C++中的实现细节 对于内置类型而言,这两种运算符的行为差异主要体现在它们的操作顺序上: - **前置++** ```cpp int a = 3; int b = ++a; // 先将a自增到4, 然后把新值4赋给b ``` - **后置++** ```cpp int c = 3; int d = c++; // 首先把c原来的值3赋给d, 接着才让c变成4 ``` 当涉及到类类型的对象时,情况变得更加复杂。为了支持这两个版本的操作符重载,程序员通常需要定义两个独立的方法来处理前缀后缀的情况。特别是后置版本往往通过传递一个额外参数(通常是无意义的整数)来进行区分[^2]。 ```cpp class MyClass { public: MyClass& operator++(); // 前置++ MyClass operator++(int); // 后置++, 参数未使用但用于区分 }; ``` #### 性能考量 由于后置版本涉及创建临时副本以便保存旧状态,因此一般认为其效率低于前置版本。这是因为每次调用后置增量都需要构造并销毁这个临时对象[^4]。 #### Java中的表现 Java 对于基本数据类型的前置后置递增/减运算法则是相同的逻辑,即前者立即改变数值后者延迟至下一次读取之前生效。然而值得注意的是,在某些情况下JVM可能会优化这些指令使得两者实际上并无太大差别。 ### 使用场景建议 选择何时使用哪种形式取决于具体需求以及个人偏好或者团队编码风格指南的要求。如果只是单纯想要修改某个变量,则推荐优先考虑前置形式因为它更高效;而在表达式内部希望获取更新之前的原始值的时候自然应该选用后置形式[^3]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值