為什么 Java 中“1000==1000”為false,而”100==100“為true?
英文原文:http://dwz.date/crTP
這是一個挺有意思的討論話題,大家可以,動手實操一下。
為什么 Java 中“1000==1000”為false,而”100==100“為true? 這是一個挺有意思的討論話題。
如果你運行下面的代碼:
Integer?a?=?1000,?b?=?1000;??
System.out.println(a?==?b);//1
Integer?c?=?100,?d?=?100;??
System.out.println(c?==?d);//2
你會得到
false
true
基本知識:我們知道,如果兩個引用指向同一個對象,用 == 表示它們是相等的。如果兩個引用指向不同的對象,用 == 表示它們是不相等的,即使它們的內(nèi)容相同。
所以事情就成了,所有的小整數(shù)在內(nèi)部緩存,然后當(dāng)我們聲明類似——
Integer?c?=?100;
的時候,它實際上在內(nèi)部做的是:
Integer?i?=?Integer.valueOf(100);
現(xiàn)在,如果我們?nèi)タ?valueOf() 方法,我們可以看到
public?static?Integer?valueOf(int?i)?{
??????if?(i?>=?IntegerCache.low?&&?i
??????????return?IntegerCache.cache\[i?+?(-IntegerCache.low)\];
??????return?new?Integer(i);
????}
如果值的范圍在 - 128 到 127 之間,它就從高速緩存返回實例。
所以…
Integer?c?=?100,?d?=?100;
指向了同一個對象。
這就是為什么我們寫
System.out.println(c?==?d);
合乎邏輯的理由是,在此范圍內(nèi)的 “小” 整數(shù)使用率比大整數(shù)要高,因此,使用相同的底層對象是有價值的,可以減少潛在的內(nèi)存占用。
public?static?void?main(String\[\]?args)?throws?NoSuchFieldException,?IllegalAccessException?{
??????Class?cache?=?Integer.class.getDeclaredClasses()\[0\];?//1
??????Field?myCache?=?cache.getDeclaredField("cache");?//2
??????myCache.setAccessible(true);//3
??????Integer\[\]?newCache?=?(Integer\[\])?myCache.get(cache);?//4
??????newCache\[132\]?=?newCache\[133\];?//5
??????int?a?=?2;
??????int?b?=?a?+?a;
??????System.out.printf("%d?+?%d?=?%d",?a,?a,?b);?//
????}
- END -
推薦閱讀
1.??8月擼書|當(dāng)當(dāng)花160買400,不擼白不擼
2.??兩難!到底用Apache BeanUtils還是Spring BeanUtils?
3.??Spring的Controller是單例還是多例?怎么保證并發(fā)的安全
之前博主分享了很多資源,有的已經(jīng)刪除了(你懂得),如果有的你當(dāng)時沒有領(lǐng)到還想領(lǐng)得就可以加我微信
回復(fù)“權(quán)限”獲取spring security與spingmvc分布式權(quán)限管理系統(tǒng) 好文章,我在看
評論
圖片
表情

