摘要:基礎(chǔ)系列的與方法類初始化順序線程池如何彈性伸縮的幾個要點的緩存什么場景下使用阻塞隊列的使用及模式中的序本文主要簡述的緩存。而如果大于或小于則它所指向的對象將符合垃圾回收的條件使用,在模式下,使用參數(shù)即可將的自動緩存區(qū)間設(shè)置為。
Java基礎(chǔ)系列
Java的hashcode與equals方法
Java類初始化順序
ThreadPoolExecutor線程池如何彈性伸縮
HashMap的幾個要點
Integer的緩存
什么場景下使用阻塞隊列
volatile的使用及DCL模式
try-catch-finally中的return
序本文主要簡述Integer的緩存。
-128~127的Integer值比較在-128~127的Integer值并且以Integer x = value;的方式賦值的Integer值在進行==和equals比較時,都會返回true,
因為Java里面對處在在-128~127之間的Integer值,用的是原生數(shù)據(jù)類型int,會在內(nèi)存里供重用,
也就是說這之間的Integer值進行==比較時只是進行int原生數(shù)據(jù)類型的數(shù)值比較,而超出-128~127的范圍,進行==比較時是進行地址及數(shù)值比較。
IntegerCache/** * Cache to support the object identity semantics of autoboxing for values between * -128 and 127 (inclusive) as required by JLS. * * The cache is initialized on first usage. The size of the cache * may be controlled by the -XX:AutoBoxCacheMax=option. * During VM initialization, java.lang.Integer.IntegerCache.high property * may be set and saved in the private system properties in the * sun.misc.VM class. */ private static class IntegerCache { static final int low = -128; static final int high; static final Integer cache[]; static { // high value may be configured by property int h = 127; String integerCacheHighPropValue = sun.misc.VM.getSavedProperty("java.lang.Integer.IntegerCache.high"); if (integerCacheHighPropValue != null) { int i = parseInt(integerCacheHighPropValue); i = Math.max(i, 127); // Maximum array size is Integer.MAX_VALUE h = Math.min(i, Integer.MAX_VALUE - (-low) -1); } high = h; cache = new Integer[(high - low) + 1]; int j = low; for(int k = 0; k < cache.length; k++) cache[k] = new Integer(j++); } private IntegerCache() {} }
IntegerCache有一個靜態(tài)的Integer數(shù)組,在類加載時就將-128 到 127 的Integer對象創(chuàng)建了,并保存在cache數(shù)組中,一旦程序調(diào)用valueOf 方法,如果i的值是在-128 到 127 之間就直接在cache緩存數(shù)組中去取Integer對象。
再看其它的包裝器:
Boolean:(全部緩存) Byte:(全部緩存) Character(<= 127緩存) Short(-128 — 127緩存) Long(-128 — 127緩存) Float(沒有緩存) Doulbe(沒有緩存)實例代碼
@Test public void testAutoBox(){ System.out.println("<-128~127以內(nèi)的Integer值,Integer x = value;的方式賦值!>"); Integer i = 127; Integer j = 127; System.out.println("i=" + i + ",j =" + j); System.out.println("i == j:" + (i == j) + "<--比較-->i.equals(j):"+ i.equals(j)); System.out.println("<-128~127以外的Integer值,Integer x = value;的方式賦值!>"); Integer m = 128; Integer n = 128; System.out.println("m=" + m + ",n =" + n); System.out.println("m == n:" + (m == n) + "<--比較-->m.equals(n):"+ m.equals(n)); System.out.println(); System.out.println("<任意Integer值,Integer x = new Integer(value);的方式賦值!>"); Integer x = new Integer(299); Integer y = new Integer(299); System.out.println("x=" + x + ",y =" + y); System.out.println("x == y:" + (x == y) + "<--比較-->x.equals(y):"+ x.equals(y)); int a = 1000, b = 1000; System.out.println(a == b); //true Integer c = 1000, d = 1000; System.out.println(c == d); //false /** * 為了節(jié)省內(nèi)存,對于下列包裝對象的兩個實例,當(dāng)它們的基本值相同時,他們總是==: Boolean Byte Character, u0000 - u007f(7f是十進制的127) Integer, -128 — 127 */ Integer e = 100, f = 100; System.out.println(e == f); //true }GC情況
/** * 這里的代碼不會有對象符合垃圾回收器的條件,這兒的i雖然被賦予null,但它之前指向的是cache中的Integer對象, * 而cache沒有被賦null,所以Integer(100)這個對象還是存在。 而如果i大于127或小于-128則它所指向的對象將符合垃圾回收的條件 使用Oracle/Sun JDK 6,在server模式下,使用-XX:AutoBoxCacheMax=NNN參數(shù)即可將Integer的自動緩存區(qū)間設(shè)置為[-128,NNN]。 注意區(qū)間的下界固定在-128不可配置。 在client模式下該參數(shù)無效。這個參數(shù)是server模式專有的,在c2_globals.hpp中聲明,默認值是128; 不過這個默認值在默認條件下不起作用,要手動設(shè)置它的值或者是開啟-XX:+AggressiveOpts參數(shù)才起作用。 -XX:AutoBoxCacheMax=20000 */ @Test public void testGc(){ Integer i = 100; i = null;//will not make any object available for GC at all. Integer j = 10000; j = null;//will make the newly created Integer object available for GC. }參考
Integer.valueOf(String) 方法之惑
Java Integer(-128~127)值的==和equals比較產(chǎn)生的思考
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/65559.html
摘要:整型對象在內(nèi)部實現(xiàn)中通過使用相同的對象引用實現(xiàn)了緩存和重用。這種緩存策略僅在自動裝箱的時候有用,使用構(gòu)造器創(chuàng)建的對象不能被緩存。行的結(jié)果為而行則為。所以行的結(jié)果為而行為。中其他類似的緩存的緩存上限可以通過虛擬機參數(shù)修改,的緩存則沒法修改。 Java5為Integer的操作引入了一個新的特性,用來節(jié)省內(nèi)存和提高性能。整型對象在內(nèi)部實現(xiàn)中通過使用相同的對象引用實現(xiàn)了緩存和重用。上面的規(guī)則默...
摘要:類實際上是中中的緩存類,目的是節(jié)省內(nèi)存消耗,提高程序性能。而當(dāng)堆內(nèi)存中的對象存儲非常多時,就有可能造成內(nèi)存泄漏。使用頻率高創(chuàng)建對象也就越多,堆內(nèi)存中的對象也就越多,所以也就會可能發(fā)生上述中的內(nèi)存溢出等問題。 面試題:問以下代碼輸出的結(jié)果是多少? public class IntegerTest { @Test public void test() { ...
摘要:對象頭的另外一部分是類型指針,即對象指向它的類元數(shù)據(jù)的指針,虛擬機通過這個指針來確定這個對象是哪個類的實例。并不是所有的虛擬機實現(xiàn)都必須在對象數(shù)據(jù)上保留類型指針,換句話說,查找對象的元數(shù)據(jù)信息并不一定要經(jīng)過對象本身,這點將在節(jié)討論。 目錄介紹 1.關(guān)于int和Integer的問題區(qū)別分析 2.Integer的值緩存的原理 2.1 Java 5 中引入緩存特性 2.2 Intege...
摘要:和的區(qū)別是的一種基本類型,則是對應(yīng)的包裝類。看到這里大概理解了為什么后兩組的結(jié)果是了吧,因為他們本身不是基礎(chǔ)類型,存儲的不是數(shù)據(jù)值,比較的時候,是去比較引用。 Integer 和 int的區(qū)別 int是Java的一種基本類型,Integer則是對應(yīng)的包裝類。 Integer的默認值是null,int的默認值是0 Integer變量必須實例化后才能使用,而int變量不需要 Intege...
摘要:作為條件變量的的不僅可以認為內(nèi)嵌了一把鎖,還內(nèi)嵌了一個條件變量。操作條件變量的函數(shù)將當(dāng)前線程在條件變量上阻塞,一般是為了等待其他線程的某件事情執(zhí)行完成。其它裝箱類其它裝箱類的代碼這里就不分析了。重點關(guān)注下各裝箱類的緩存范圍。 jdk源碼讀到現(xiàn)在這里,重要的集合類也讀了一部分了。集合類再往下讀的話,就要涉及到兩個方向。第一,是比較典型的但是不常用的數(shù)據(jù)結(jié)構(gòu),這部分我準備將數(shù)據(jù)結(jié)構(gòu)復(fù)習(xí)、回...
閱讀 1200·2021-09-22 15:24
閱讀 2298·2019-08-30 15:44
閱讀 2626·2019-08-30 10:55
閱讀 3366·2019-08-29 13:25
閱讀 1651·2019-08-29 13:09
閱讀 1405·2019-08-26 14:05
閱讀 1397·2019-08-26 13:58
閱讀 1988·2019-08-26 11:57