Java的i=i+1的内存模型原理

今天遇到这样的一道题目

package algorithms.com.guan.javajicu; 
public class Inc { 
    public static void main(String[] args) { 
       Inc inc = new Inc(); 
       int i = 0; 
       inc.fermin(i); 
       i= i ++; 
       System.out.println(i);
    
    } 
    void fermin(int i){ 
       i++; 
    } 
}

求最后i等于多少?

法1

这道题目有两种思路,第一个是我们可以把i++看成某一具体函数的实现:

int getI(int &i){
    int temp = i;
    i=i+1;
    return temp;
}
注意这里写成 &i 是为了说明不是传值

这样就很好理解了,虽然在过程中函数自加1变成了1,但是因为题目中最后又把返回值赋值给了i,也就是temp赋值给了i,但是此时temp还是0,因此最后i=0;


法2

从java虚拟机的内存模型来理解,java中每个方法的执行都是基于“栈帧”的,每个栈帧中都有 局部变量表 操作数栈 ,可以把它看成是两段内存空间,对于下面两句代码:

 int i = 0; 
 i= i ++; 

转化成字节码之后的执行流程如下:

首先是0进入操作数栈栈顶,然后弹出放到局部变量表位置为1的地方存储(对应int i=0),然后把局部变量表位置为1的数的副本复制到操作数栈,对局部变量表的位置为1的数自增1(对应i++),最后再把操作数栈栈顶的0移动到局部变量表的位置1,覆盖了刚才的1,又变成了0;

可以画出示意图:

至于fermin函数,因为基本数据类型是值传递,因此没有影响。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值