Java中间缓存变量机制(i++)

Java程序员面试宝典(第二版)中有这样一道笔试题:

/**下列程序的输出结果是()*/
import java.util.*;
public class Test{
    public static void main(String[] args){
        int j = 0;
        for(int i=0;i<100;i++){
            j = j++;
        }
        System.out.println(j);
    }
}
正确结果:程序的运行结果是 0

结果很像是 100,为什么是 0?

因为Java用了中间缓存变量机制,所以j=j++;可以换成如下写法:

temp = j;
j = j++;
temp = j;
所以结果是 0 。(此为书中解释)

至此貌似是明白了!那么再来一题:

/**下来代码执行的结果*/
import java.util.*;
public class Test2{
	public static void main(String args[]){
		int i = 0;
		i = i++ + ++i;
		
		int j = 0;
		j = ++j + j++ + j++ + j++;
		
		int k = 0;
		k = k++ + k++ + K++ + ++k;
		
		int h = 0;
		h = ++h + ++h;
		
		System.out.println("i="+i);
		System.out.println("j="+j);
		System.out.println("k="+k);
		System.out.println("h="+h);
	}
}

i=2

j=7

k=7

h=3

看到结果貌似不是真的明白Java的 i++和++i !

问题实质:在java中,执行自增运算时,会为每一个自增操作分配一个临时变量,如果是前缀加(++i),就会“先自加1后赋值(给临时变量)”;如果是后缀加(i++),就会“先赋值(给临时变量)后自加1”。运算最终使用的,并不是变量本身,而是被赋了值的临时变量。

上述程序计算方法:

 int i = 0;
 i = i++ + ++i; //i=2,等效执行以下程序  
  /*   
   * temp1 = i;        //i=0,temp1=0 
   * i = i + 1;        //i=1   
   * i = i + 1;        //i=2   
   * temp2 = i;        //i=2,temp2=2  
   * a = temp1 + temp2 //i=2;   
   */    
  int j = 0;  
  j = ++j + j++ + j++ + j++;  //j=7    
  /*   
   * j = j + 1;        //j=1   
   * temp1 = j;        //j=1 , temp1=1 

   * temp2 = j;        //j=1, temp2=1 
   * j = j + 1;        //j=2 
   
   * temp3 = j;		   //j=2,temp3=2
   * j = j + 1;        //j=3
   
   *temp4 = j;         //j=3 ,temp4=3
   *j = j + 1;         //j=4
   
   * j = temp1 + temp2 + temp3 + temp4 //j=7;   
   */    
  
  int k = 0;  
  k = k++ + k++ + K++ + ++k; //k=22    
  /*   
   * temp1 = k;        //k=0, temp1=0 
   * k = k + 1;        //k=1 
   
   * temp2 = k;		   //k=1,temp2=1
   * k = k + 1;        //k=2
   
   *temp3 = k;         //k=2 ,temp3=2
   *k = k + 1;         //k=3

   * k = k + 1;        //k=4   
   * temp4 = k;        //k=4 , temp4=4 
   
   * k = temp1 + temp2 + temp3 + temp4 //k=7;    
   */    
    
  int h = 0;
  h = ++h + ++h; //h=3    
  /*   
   * h = h + 1;        //h=1   
   * temp1 = h;        //k=1 , temp1=1 
   
   * h = h + 1;        //h=2   
   * temp2 = h;        //h=2, temp2=2 
   * h = temp1 + temp2 //h=3;   
   */ 

需要注意的是: C语言中的计算方法和Java不同

本文系个人总结,后发现相似博文,请大家参考!

http://blog.csdn.net/ffanfanm/article/details/12784489

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
java缓存实现demo完整实例,很不错的资源,欢迎大家来下载学习。/** * 此函数接受一个对象列表,数目不定,opration:表是触发的事件 * eg:change;fnClear:表示初始化下拉框。var_args表示多个下拉框... */ function bindSelects(operation, initSelectObj, loadShow, var_args){ //每个argument对象都有一个 change事件 //change事件会触发:此argument之后的对象清空,紧跟此对象的后一对象发送ajax请求 var elementList = []; for (var i = 3; arguments[i]; i++) { elementList[i-3] = arguments[i]; } for (var i = 0; elementList[i]; i++) { (function(k) { elementList[k].bind(operation, function(){ selectType = elementList[k].attr("name"); //其后的对象进行某个操作 for (var j = k+1; elementList[j]; j++) { if (initSelectObj && initSelectObj.constructor===Function) { if(elementList[k].val() == "") { initSelectObj(elementList[j],elementList[j].data(SELECT_KEY)); LOAD_KEYS[j].hide(); } else{ initSelectObj(elementList[j],elementList[j].data(SELECT_KEY)); } } } //紧跟对象发送ajax if (elementList[k+1]) { if(elementList[k].val() != "") { //从页面缓存取出 if(elementList[k+1].data(elementList[k].val())) { var data = elementList[k+1].data(elementList[k].val()); var key=LIST_KEYS[k]; var jsonKey = [key]; addContentToSelect(data,jsonKey,elementList[k+1]); } else { //从缓存取出数据 if (fnAjax && fnAjax.constructor===Function) { loadShow(LOAD_KEYS[k+1]); fnAjax(elementList[k+1].data(SELECT_KEY),LIST_KEYS[k],LOAD_KEYS[k+1],elementList[k],selectType); } } } } }); })(i); } }

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值