深入理解自增自减运算符,看懂表达式不糊涂

自增运算符(++)和自减运算符(- - )在算术表达式中容易造成使用上的错误,主要原因有两点:一是自增运算符和自减运算符在变量前后的位置不一样,其内部逻辑不一样。二是自增运算符和自减运算符只能用于变量,不能用于常量。

  • 首先讲解一下自增自减运算符的概念,自增自减运算符存在于高级语言中,它的作用是在运算结束前(前置自增自减运算符)或后(后置自增自减运算符)将变量的值加(或减)一。
  • 对于第一点原因,我们需要了解计算机编译程序对表达式的处理过程。编译程序对表达式的处理,需要借助栈来完成,栈的特点是先进后出,计算机 从左向右扫描表达式,对于后置自增或自减运算符,先将操作数压入栈中,然后再进行自增后自减操作,在进行运算时将压入栈中的数弹出来进行运算,而前置的自增或自减运算符相反,是先将操作数进行自增或自减操作,然后再压入栈中,运算时将栈中的数弹出进行计算。举例如下:
 int a = 1;
 int b = 2;
 int c = 0;
 c = a++ + b++ + ++a;
 system.out.println("a="+a+",b="+b+",c="+c);

运行结果a=3,b=3,c = 6.
分析过程如下:
第一步:从左向右扫描表达式,遇到a++,将a = 1压入栈中(即栈中存储的数值为1,在计算时弹出的值为1),a加1,此时a = 2。
第二步:继续扫描,遇到b++,将b=2压入栈中(即栈中存储的数值为2,在计算时弹出的值为2),b加1,此时b=3。
第三步:继续扫描,遇到++a,由于在第一步中a已经变成2,此时先自增,a=3,压入栈中(即栈中存储的数值为3,在计算时弹出的值为3)。
第四步:进行计算,将压入栈中的数依次弹出,分别是a=3,b=2,a=1,计算可得c=1+2+3=6,此时a=3,b=3.
再举一个例子:

int a = 1;
a = a++;
 system.out.println("a="+a);

可能有的人会认为输出结果为a = 2,这是错误的,a的值为1,我们对表达式进行分析,扫描表达式,遇到a++,将a=1压入栈中,此时a自增,变为2,进行计算,将栈中的1弹出,赋值给a,此时a的值仍然为1。
通过上面的例子分析应该可以清晰的看懂自增自减运算符在表达式中的处理过程。

  • 对于第二点原因,自增自减运算符只能用于操作数是变量的情况,不能用于常量的情况,例如:
#define PI 3.1415926
 PI++

这种情况是错误的,再比如:3++,这种情况同样是错误的。

本人水平有限,如有不足之处欢迎各位指正,或者有疑问的可以在评论区提出。

  • 28
    点赞
  • 80
    收藏
    觉得还不错? 一键收藏
  • 17
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 17
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值