i++和++i的區別

近期一道面試題,難道了很多學java的人。i++和++i到底有什麼區別。下面先來看這段代碼。

 

/**
 * i++和++i對比
 * @author Shoper
 */
public class I {
	public static void main(String[] args) {
		int cv=0;
		for (int i = 0; i < 10; i++) {
			cv=cv++;
		}
		System.out.println(cv);
		int cc=0;
		for (int i = 0; i < 10; i++) {
			cc=++cc;
		}
		System.out.println(cc);
	}
}

第一次cv自加。再次賦值給cv變量。看上去cv++賦值給cv時,先把值賦給cv再自加,並把cv值變爲1,其實不然。java內部是把cv++計算的值放到內存中。而賦給cv的值依然是0,其實是因爲cv=cv++;就相當於cv=cv;所以無論加循環cv=cv++幾次結果cv依然爲初始值0;

2015-05-18號,心血來潮在師傅(@超級細菌-彭宇昕)的幫助下反彙編了下a=a++的代碼;才明白了具體原因.

ShawnShoperdeMacBook-Pro:~ ShawnShoper$ otool -tv a.out
a.out:
(__TEXT,__text) section
_main:
0000000100000f80	pushq	%rbp
0000000100000f81	movq	%rsp, %rbp
0000000100000f84	xorl	%eax, %eax
0000000100000f86	movl	$0x0, -0x4(%rbp)   a=0
0000000100000f8d	movl	-0x4(%rbp), %ecx   a放入%ecx
0000000100000f90	movl	%ecx, %edx	   把%ecx放入%edx
0000000100000f92	addl	$0x1, %edx   取出%edx然後+1  a++
0000000100000f98	movl	%edx, -0x4(%rbp)   取出%edx給 變量a
0000000100000f9b	movl	%ecx, -0x4(%rbp)   再取出%ecx(此時依然爲0)給變量a
0000000100000f9e	popq	%rbp
0000000100000f9f	retq
ShawnShoperdeMacBook-Pro:~ ShawnShoper$ 

所以通過以上分析a=a++; 其實是 

b=a;

a=b+1; 

a=a;

這樣一步操作

-------------------------------

第二次的cc自加。根據++i的道理.先自加再把值返回.那麼cc= cc+1;

所以結果一目瞭然第一個結果爲0,第2個結果10;


發佈了30 篇原創文章 · 獲贊 4 · 訪問量 8萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章