一、Java中“1000==1000”為false,而”100==100“為true的原因
Java 5 引入了自動(dòng)裝箱和自動(dòng)拆箱功能,這使得基本數(shù)據(jù)類型和它們對(duì)應(yīng)的包裝類可以在需要時(shí)自動(dòng)轉(zhuǎn)換。例如,當(dāng)將一個(gè) int
類型的值賦給一個(gè) Integer
對(duì)象時(shí),編譯器會(huì)自動(dòng)執(zhí)行裝箱操作,將基本數(shù)據(jù)類型轉(zhuǎn)換為其對(duì)應(yīng)的包裝類。
為了提高性能,Java 在自動(dòng)裝箱過程中實(shí)現(xiàn)了一個(gè)名為整數(shù)緩存(Integer Cache)的機(jī)制。這個(gè)機(jī)制會(huì)緩存一定范圍內(nèi)的整數(shù)對(duì)象。在 Java 的默認(rèn)實(shí)現(xiàn)中,緩存的范圍是 -128 到 127(包括邊界值)。因此,當(dāng)自動(dòng)裝箱一個(gè)位于這個(gè)范圍內(nèi)的整數(shù)時(shí),將返回緩存中的相同整數(shù)對(duì)象。
在 Java 中,使用 “==” 操作符比較對(duì)象時(shí),實(shí)際上是比較它們的引用是否相等,而不是它們的內(nèi)容是否相等。如果想要比較兩個(gè)對(duì)象的內(nèi)容是否相等,通常需要使用它們的 equals()
方法。
然而,當(dāng)使用 “==” 操作符比較基本數(shù)據(jù)類型時(shí),實(shí)際上是比較它們的值是否相等。
在這里,我們實(shí)際上是比較兩個(gè) Integer
對(duì)象,而非基本數(shù)據(jù)類型 int
。
當(dāng)我們比較兩個(gè)值為 100 的 Integer
對(duì)象時(shí),由于這兩個(gè)對(duì)象的值都在整數(shù)緩存的范圍內(nèi)(-128 到 127),它們會(huì)指向緩存中的同一個(gè)對(duì)象。因此,使用 “==” 操作符比較它們的引用時(shí),結(jié)果為 true。
然而,當(dāng)我們比較兩個(gè)值為 1000 的 Integer
對(duì)象時(shí),由于它們的值超出了整數(shù)緩存的范圍,Java 不會(huì)使用緩存中的對(duì)象。因此,這兩個(gè) Integer
對(duì)象分別在堆內(nèi)存中的不同位置,使用 “==” 操作符比較它們的引用時(shí),結(jié)果為 false。