Java中间变量缓存机制

 

Java中间变量缓存机制

先上代码:

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. public class Demo {   
  2.     public static  void main(String[] args){          
  3.         method_1();  
  4.         method_2();   
  5.     }  
  6.       
  7.     private static void method_1(){  
  8.         int j = 0;  
  9.         for(int i=0;i<100;i++){            
  10.             j = j++;                          
  11.         }         
  12.         System.out.println("method_1---"+j);      
  13.     }  
  14.       
  15.     private static void method_2(){  
  16.         int j = 0;  
  17.         for(int i=0;i<100;i++){            
  18.             j = ++j;                          
  19.         }         
  20.         System.out.println("method_2---"+j);      
  21.     }  
  22. }<strong>  
  23. </strong>  

大家猜一下输出结果是什么?

|

|

|

|

|

|
|
|
|
|
|
|
|
|

输出结果是:

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. method_1---0  
  2. method_2---100  

为什么会是这样呢?

因为在计算过程中,使用了Java中间变量缓存机制。在java中,执行自增运算时,会为每一个自增操作分配一个临时变量,如果是前缀加(++i),就会“先自加1后赋值(给临时变量)”;如果是后缀加(i++),就会“先赋值(给临时变量)后自加1”。运算最终使用的,并不是变量本身,而是被赋了值的临时变量


即 method_1方法中的

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. j = j++;  

等同于:

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. int temp = j;  
  2. j = j + 1;  
  3. j = temp;  

method_2方法中的

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. j = ++j;  
等同于:

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. j = j + 1;  
  2. int temp = j;  
  3. j = temp;  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值