中间缓存变量机制 i++

最近在看java面试题,看到了一道经典的i++题目,内容如下:

@Test
public void test1(){
	int j=0;
	for(int i=0;i<100;i++) {
		j=j++;
	}
	System.out.println(j);
}

相信有很多小伙伴一看到题目就会说,简单,结果是100。可惜,输出结果是0,。

为什么会是这个结果呢,这就涉及到java的中间缓存变量机制。

在jvm里面有两个存储区,一个是暂存区(是一个堆栈,以下称为堆栈),另一个是变量区。在java中,执行自增运算时,会为每一个自增操作分配一个临时变量,存储在暂存区。
即j=j++;是先将j的值(0)存入堆栈,然后对变量区中的j自加1,这时j的值的确是1,但是随后又将堆栈的值(0)弹出赋给变量区的j,所以最后j= 0。
即j=j++; 等同于:
int temp=j;//temp=0
j=j+1;//j=1
j=temp;//j=0

接着,让我们再看一个程序:

@Test
public void test2() {
    int j=0;
    for(int i=0;i<100;i++) {
	j++;
    }
    System.out.println(j);
}

毫无疑问,该程序的执行结果为100。

当我们把循环体中的j=j++;换成j++;时,同样会产生临时变量,但因为j++中没有最后那个赋值,所以j实现了自增。


如果文章有错的地方欢迎指正,大家一起交流学习。

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值