Java的自动装箱与拆箱
為什么80%的碼農都做不了架構師?>>> ??
public?class?Test?{public?static?void?main(String[]?args)?{Integer?n1?=?1;Integer?n2?=?1;Integer?n3?=?128;Integer?n4?=?128;System.out.println(n1?==?n2);System.out.println(n3?==?n4);} } //?output true false????????為什么一個是true一個是false呢,只是將1改成了128,僅此而已。 ? ?
????????Java5開始引入了atuoboxing(自動裝箱)和auto-unboxing機制,方便了基本類型和其對于的wrapper類型的轉換。例如,我們可以直接把一個基本類型的值賦給其wrapper類型,反之亦然;可以把一個基本類型直接放入容器里,封裝的過程由編譯器來完成。這個過程中,編譯器只是做了簡單的處理,通過wrapper calss的valueOf()方法對基本類型進行包裝,通過wrapper class的“基本類型名稱”+value()方法得到其基本類型。
public?static?Integer?valueOf(int?i)
? ? ? ?返回一個表示指定的 int 值的 Integer 實例。如果不需要新的 Integer 實例,則通常應優先使用該方法,而不是構造方法 Integer(int),因為該方法有可能通過緩存經常請求的值而顯著提高空間和時間性能。這是JDK文檔對該方法的說明。
????????那么何時不需要新的Integer實例?Byte,Integer 和Long都是緩存了-128~+127之間的對象,autoboxing的時候,如果需要boxing的值在此范圍之內,則直接返回緩存的對象,沒有的時候再去new。這就解釋了第二個結果為什么是false.
????????Boolean類型中直接緩存了兩個Boolean對象,true和false,這樣使用valueOf()方法時只需要直接返回這兩個對象中的一個,而不是每次調用的時候都用new,這也就是文檔里所說的通過緩存經常請求的值二顯著提高空間和時間性能。
????????Character因為類型的特殊性,保存的是0~127之間的對象。
轉載于:https://my.oschina.net/yinjq/blog/17264
總結
以上是生活随笔為你收集整理的Java的自动装箱与拆箱的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: asp.net引用用户控件
- 下一篇: C#实现的一个内存Ini类