Java整數(shù)池。為什么?
它被稱為Flyweight模式,用于最小化內(nèi)存使用。
這些數(shù)字很可能會被重復(fù)使用,并且類似autoBox的類型Integer是不可變的(請注意,這樣做不僅是針對Integer)。緩存它們可以使實例不多,并且也減少了GC(垃圾收集)的工作。
JLS在5.1.7中對此進(jìn)行了介紹。裝箱轉(zhuǎn)換專門通過說:
如果裝箱的值p為true,false,字節(jié)或 u0000到u007f范圍內(nèi)的char或-128到127(含)之間的整數(shù)或短數(shù),則令r1和r2為p的任何兩次拳擊轉(zhuǎn)換。r1 == r2總是這樣。
理想情況下,將給定的原始值p裝箱將始終產(chǎn)生相同的參考。實際上,使用現(xiàn)有的實現(xiàn)技術(shù)可能不可行。以上規(guī)則是務(wù)實的妥協(xié)。上面的最后一句要求始終將某些通用值裝在無法區(qū)分的對象中。該實現(xiàn)可以懶惰地或急切地緩存它們。對于其他值,此公式不允許對程序員方面的帶框值的身份進(jìn)行任何假設(shè)。這將允許(但不要求)共享部分或全部這些引用。
這樣可以確保在最常見的情況下,行為將是理想的,而不會造成不必要的性能損失,尤其是在小型設(shè)備上。例如,較少內(nèi)存限制的實現(xiàn)可能會緩存所有char和short值,以及-32K到+32K范圍內(nèi)的int和long值。
解決方法我到處都讀到過,當(dāng)您在Java中定義介于-128到127之間的Integer時,它不會創(chuàng)建新對象,而是返回已經(jīng)創(chuàng)建的對象。
除了讓新手程序員比較Integer對象==以查看它們是否具有相同的數(shù)字外,我看不到這樣做的任何意義,但是我認(rèn)為這很糟糕,因為確保他們認(rèn)為可以將任何Integer對象與進(jìn)行比較==,并且還在教學(xué)在任何編程語言中都不好的做法:將兩個“不同”對象的內(nèi)容與進(jìn)行比較==。
這樣做有其他原因嗎?還是在設(shè)計語言(以我的觀點)(如JavaScript中的可選分號)時只是一個錯誤的決定?
編輯:我在這里看到他們解釋行為:為什么Integer常量池的行為在127發(fā)生變化?
我在問為什么他們設(shè)計它具有這種行為,而不是為什么會發(fā)生這種行為。
相關(guān)文章:
1. java - ehcache緩存用的是虛擬機(jī)內(nèi)存么?2. javascript - JS如何取對稱范圍的隨機(jī)數(shù)?3. 數(shù)據(jù)庫 - mysql如何處理數(shù)據(jù)變化中的事務(wù)?4. javascript - vue 移動端的input 數(shù)字輸入優(yōu)化5. android - java 泛型不支持?jǐn)?shù)組,那么RxJava的Map集合有什么方便的手段可以定義獲得一串共同父類集合數(shù)據(jù)呢?6. 為什么我ping不通我的docker容器呢???7. javascript - 有什么兼容性比較好的辦法來判斷瀏覽器窗口的類型?8. 關(guān)于docker下的nginx壓力測試9. java - mongodb分片集群下,count和聚合統(tǒng)計問題10. java 隨機(jī)延遲執(zhí)行
