Java 中的自動裝箱不規則性:調查神秘的比較
Java 的自動裝箱功能會自動將原始值轉換為其相應的包裝類物件。然而,當比較兩個這樣的物件時,會出現一種奇怪的行為。
考慮以下程式碼片段:
public class Scratch { public static void main(String[] args) { Integer a = 1000, b = 1000; System.out.println(a == b); // false Integer c = 100, d = 100; System.out.println(c == d); // true } }
輸出讓我們困惑:第一個比較產生 false,而第二個比較回傳 true。為什麼會這樣呢?
揭開謎底
第二行輸出是由Java語言規範(JLS)保證的。第 5.1.7 節規定,特定範圍內的原始值(包括 -128 到 127 之間的整數)始終裝箱到相同的物件中。
If the value p being boxed is ... an int or short number between -128 and 127, then ... r1 == r2.
這確保常用值始終裝箱為不可區分的物件。
開頭的歧義比較
相較之下,JLS 沒有明確保證第一個比較。雖然規範允許實作在一定範圍內快取對象,但它並不會強制執行。
因此,將較大整數作為物件進行比較的行為是特定於實現的。在這種情況下,運行時環境似乎為“a”和“b”分配了不同的引用,導致列印“false”。
結論
Java 的自動裝箱提供了便利,但在比較某些原始值時也有一些怪癖。雖然定義範圍內的值保證共享身份,但較大的整數可能會根據實現選擇而表現不同。這些知識可以幫助我們避免意外行為並保持對 Java 中物件比較的控制。
以上是為什麼 Java 的自動裝箱在比較整數物件時會產生不一致的結果?的詳細內容。更多資訊請關注PHP中文網其他相關文章!