i++,++i经典解析

 

package com.aozhi.cailinyan;

public class IpulsPuls {
	public static void main(String[] args) {
		//i++ 先把i压入操作数栈 在自增。
		//++i 把++i计算出来压入操作数栈。
		int i = 1;
		i = i++; //i压入操作数栈【1】,i++ 为2 ,完之后操作数栈又赋值给i 所以i=1(曾经等于2又被操作数栈给覆盖回1了)
		int j = i++;//i压入操作数栈【1】,i++ i为2,完之后操作数栈又赋值给j 所以j=1 i=2
		int k = i + ++i * i++;//i压入操作数栈【2】,++i压入操作数栈【3】i压入操作数栈【3】 (此时i++ i=4)相乘得9 ;操作数栈最终结果【2+9=11】,完之后又赋值给k=11,i=4。
		System.out.println(i);
		System.out.println(j);
		System.out.println(k);
		System.out.println(i);
	}
}

打印结果:

4
1
11
4

 

总结:

  • 赋值=,最后计算
  • =右边从左到右加载值依次操作数栈
  • 实际先算哪个,看优先级运算符
  • 自增。自减的操作都是直接修改变量的值,不经过操作数栈
  • 最后在赋值之前,临时结果也是存储在操作数栈里

 

建议观看:《JVM虚拟机规范》关于指令的部分

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值