java中的數據類型,可分爲兩類:
java
也稱原始數據類型。byte,short,char,int,long,float,double,boolean
spa
他們之間的比較,應用雙等號(==),比較的是他們的值。
對象
當他們用(==)進行比較的時候,比較的是他們在內存中的存放地址,因此,除非是同一個new出來的對象,他們的比較後的結果爲true,不然比較後結果爲false。 JAVA當中全部的類都是繼承於Object這個基類的,在Object中的基類中定義了一個equals的方法,這個方法的初始行爲是比較對象的內存地 址,但在一些類庫當中這個方法被覆蓋掉了,如String,Integer,Date在這些類當中equals有其自身的實現,而再也不是比較類在堆內存中的存放地址了。
繼承
對於複合數據類型之間進行equals比較,在沒有覆寫equals方法的狀況下,他們之間的比較仍是基於他們在內存中的存放位置的地址值的,由於Object的equals方法也是用雙等號(==)進行比較的,因此比較後的結果跟雙等號(==)的結果相同。內存
public class TestString {ci
public static void main(String[] args) {資源
String s1 = "Monday";字符串
String s2 = "Monday";編譯
if (s1 == s2)class
{
System.out.println("s1 == s2");}
else{
System.out.println("s1 != s2");}
}
}
編譯並運行程序,輸出:s1 == s2說明:s1 與 s2 引用同一個 String 對象 -- "Monday"!
public class TestString {
public static void main(String[] args) {
String s1 = "Monday";
String s2 = new String("Monday");
if (s1 == s2)
{System.out.println("s1 == s2");}
else
{System.out.println("s1 != s2");}
if (s1.equals(s2)) {System.out.println("s1 equals s2");}
else{
System.out.println("s1 not equals s2");}
}
}
咱們將s2用new操做符建立
程序輸出:
s1 != s2
s1 equals s2
說明:s1 s2分別引用了兩個"Monday"String對象
原來,程序在運行的時候會建立一個字符串緩衝池當使用 s2 = "Monday" 這樣的表達是建立字符串的時候,程序首先會在這個String緩衝池中尋找相同值的對象,在第一個程序中,s1先被放到了池中,因此在s2被建立的時候,程序找到了具備相同值的 s1
將s2引用s1所引用的對象"Monday"
第二段程序中,使用了 new 操做符,他明白的告訴程序:"我要一個新的!不要舊的!"因而一個新的"Monday"Sting對象被建立在內存中。他們的值相同,可是位置不一樣,一個在池中游泳一個在岸邊休息。哎呀,真是資源浪費,明明是同樣的非要分開作什麼呢?
public class TestString {
public static void main(String[] args) {
String s1 = "Monday";
String s2 = new String("Monday");
s2 = s2.intern();
if (s1 == s2)
{System.out.println("s1 == s2");}
else
{System.out.println("s1 != s2");}
if (s1.equals(s2)) {System.out.println("s1 equals s2");}
else{
System.out.println("s1 not equals s2");}
}
}
此次加入:s2 = s2.intern();程序輸出:s1 == s2s1 equals s2原 來,(java.lang.String的intern()方法"abc".intern()方法的返回值仍是字符串"abc",表面上看起來好像這個方 法沒什麼用處。但實際上,它作了個小動做:檢查字符串池裏是否存在"abc"這麼一個字符串,若是存在,就返回池裏的字符串;若是不存在,該方法會 把"abc"添加到字符串池中,而後再返回它的引用。)