您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關JDK1.5封箱及拆箱功能操作時注意的問題是什么,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
我們知道Java中所有到的類型要么就是引用類型和要么就是原始數據類型,其中原始數據類型有其相應的包裹類(Wrapper Class),包括:Byte(byte), Short(short), Integer(int), Long(long), Float(float), Double(double), Boolean(bool), Char(char)。
我們將原始數據類型及其包裹類間的互相轉換稱為封箱及拆箱操作。
Generics為我們提供了自動封拆箱的功能,記住在設定泛型的類型參數(type parameter時,只能使用引用類型,絕對不能使用原始數據類型。我們以以下的示例來說明:
Example1.2.1
public int sum(List ints) { int s = 0; for(int n : ints) {s += n;} return s; }
在該例子,我們看到在遍歷時,當ints把值綁定到n時,進行了拆箱操作。
Example1.2.2
public Integer sumInteger(List ints) { Integer s = 0; for(Integer n : ints) { s += n;} return s; }
在這里我們看到在進行s += n這一步時,反復做了拆箱及封箱操作,我們看到雖然做的是同一件事,但在JVM中執行的效率相差幅度在60%左右。
在討論封,拆箱時我們要留意一下以下兩個問題:
(1)==號在原始及引用類型間的定義是不同的,我們在處理比較相等問題時要特別留意封,拆箱帶來的問題:
Example1.2.3
List bigger = new ArrayList(200, 300, 400); Assert sumInteger(bigger) == sum(bigger); Assert sumInteger(bigger) != sumInteger(bigger) //not recommended
我們看到在***段比較時,對Integer進行了拆箱的操作,然后再和int比較,則結果一定是900.第二個比較,因為兩者都為Integer,但它們并不是同一對象的引用,所以自然就不相等。
我們推薦使用==號比較int類型,用equals方法去比較Integer類型間的相等性。
(2)當對byte, boolean,int(-127 - +128), short(-127 - +128), char(\u0000 - \u007f)在封箱時是必須進行緩存的,而對其它值,也是被允許進行緩存。
Example1.2.4
List smalls = new List(1,2,3); Assert sumInteger(smaller) == sum(smaller); Assert sumInteger(smaller) == sumInteger(smaller) //not recommended
因為總和的值為6,所以封箱后的值被緩存起來,下次封箱的值也為6時,就會調用緩存中的值,所以我們看到第二個判斷為相等。通常情況下,并沒有指定封箱兩次相同的值會返回相同或不同對象。我們反對用==號進行引用對象的比較,而是使用equals方法來進行判斷對象間的相等情況。
看完上述內容,你們對JDK1.5封箱及拆箱功能操作時注意的問題是什么有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。