递增运算

关于递增的运算,虽然看起来没有什么难度,但在有些面试笔记中却常常出现:
首先我们来看看++的一个运算原理:

i++的工作原理,程序会首先保留i在执行自增运算之前的值,用来参与运算,然后将i的值增1。
k=i++
k=i
x=x+1

++i的工作原理,程序会首先将i加上1,然后把结果赋给自己,再放入到表达式中运算。  
k=++i          
i=i+1
k=i;

从以上的运算的一个结果可以看到一点,就是无论是前加加还是后加加,i的值始终都会加1.
下面来看一道变态的题:

int i=1,k=1,a=0,b=0;

a=2*i+++4+i++;
b=2*++k+4+(++k);

算出a和b分别是多少?
其实我们一般不会这么写,就算这么变态的题出现了,也是跟机器来运算的。但如果你静下心来算算,我敢打赌,10个人有8个人会算错,那剩下的两个人一个是出题的,一个是高手。
如果算不下去,可以放在eclipse里看看结果。


public class IncreasPlus {
	
	public static void main(String[] args) {		
		int i=1,k=1,a=0,b=0;
		
		a=2*i+++4+i++;//这个算式从左至右,首先,i*2进行运算,运算完成后i自加一次,然后,2+4进行运算=6,最后6+i,注意此时的i已经为2了,然后i再自加一次。	
		b=2*++k+4+(++k);//这个算式由于小括号的加入,给人第一眼的错觉好像是要先运算++k,如果是这样算就是12了,但其实括号在这里只是做一个分隔而已.
		System.out.println("a="+a+" "+"b="+b);
		System.out.println("i="+i+" "+"k="+k);
		// int b=2*++k+4+(++k);
		// int b=2* ++k + 4 + (++k);
		// int b=2* 2 + 4 + 3;
		// int b=4 + 4 + 3;				
		// int b=11;		
	}	
	
}



猜你喜欢

转载自show213.iteye.com/blog/1888696