1. 程式人生 > >java面試題之==和equlas的區別

java面試題之==和equlas的區別

面試失敗第一次

==和equals的區別

java中的資料型別,可分為兩類: 1.基本資料型別 也稱原始資料型別。byte,short,char,int,long,float,double,boolean 原始資料型別之間的比較,應該用雙等號“==”,比較的是他們的值。

2.複合資料型別(類) 除了以上的基本資料型別,其他的引用都是複合資料型別,如String,陣列,一般的class類,介面 e1,e2也是複合資料型別

Employee e1,e2;
e1=new Employee("王勁",26,6300);
e2=new Employee("張山",30,3800);

當他們用“==”進行比較的時候,比較的是他們在記憶體中存放的地址,所以,除非是同一個new出來的物件,他們的比較後的結果為true,否則比較後結果為false。

JAVA當中所有的類都是繼承於Object這個基類的,在Object中的基類中定義了一個equals的方法,這個方法的初始行為是比較物件的記憶體地址,但在一些類庫當中這個方法被覆蓋掉了,如String,Integer,Date在這些類當中equals有其自身的實現,而不再是比較類在堆記憶體中的存放地址了。 對於複合資料型別之間進行equals比較,在沒有覆蓋重寫equals方法的情況下,他們之間的比較還是基於他們在記憶體中的存放位置的地址值的,因為Object的equals方法也是用雙等號“==”進行比較的。

所以比較後的結果跟直接用“==”的結果相同。

個人簡單總結: 基本資料型別用“==”比較值即可。

複合資料型別,“==”比較的是2個物件的地址,而equals比較的是2個物件的內容。

顯然,當equals為true時,“==”不一定為true。

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被建立的時候,如果不使用new,程式就只會找到了具有相同值相同地址的 s1。

所以s2引用的是s1所引用的物件"Monday"。

在程式中,使用了 new 操作符,他明白的告訴程式:"我要一個新的!不要舊的!"於是一個新的"Monday"Sting物件被建立在記憶體中。他們的值相同,但是地址不同,一個在深水區游泳一個在淺水區游泳,雖然他們都在游泳,但所處的區域不同。哎呀,真是資源浪費,明明是一樣的非要分開做什麼呢?

如果要new出來的“==”且equals成功,只需要在new的s2後面加多一句

String s2 = new String("Monday");
s2 = s2.intern();

java.lang.String的intern()方法"abc".intern()方法的返回值還是字串"abc",表面上看起來好像這個方法沒什麼用處。但實際上,它做了個小動作:檢查字串池裡是否存在"abc"這麼一個字串,如果存在,就返回池裡的字串;如果不存在,該方法會 把"abc"新增到字串池中,然後再返回它的引用。