在JAVA中有兩種方法比較對象是否相等. 那么首先如何判斷一個對象是否相等?判斷對象是否相等實際上是比較對象的內(nèi)存地址,準確的來講是比較對象的引用是否引用的同一個內(nèi)存地址。
“==”是用來比較內(nèi)存地址的運算符. equals();方法是比較兩個對象的值是否相同.
有以下代碼:
String s1 = "abc";
String s2 = "abc";
那么 s1==s2 返回true. s1.equals(s2)也是返回true;
因為String對象變量s1,s2 都是引用一個String對象"abc"的內(nèi)存地址的,所以 s1==s2 為true, 又因為s1的值是"abc" ,s2 的值也是"abc", 所以s1.equlas(s2)返回的也是true.
請看以下代碼:
String s1 = new String("abc");
String s2 = new String("abc");
那么s1==s2 返回的是false, 而s1.equals(s2)返回的是true;
因為s1引用內(nèi)存中的一個對象(此對象的值為"abc"), s2也引用內(nèi)存中的一個對象(值也為"abc"),既然"=="號比較的是內(nèi)存地址.那么這里s1==s2應(yīng)該返回的是true才對啊, 如果你有這樣的想法.那么是由于你會覺得兩句new String("abc")創(chuàng)建出來的對象是一樣的! 其實不是一樣的.為什么呢?? 如果是String s1 ="abc" ;的方式賦值的話,那么虛擬機會在他自己的常量池中先查找有沒有"abc"的常量對象.如果有則賦值,如果沒有則創(chuàng)建一個,但是 用 new String();語句實際上是在內(nèi)存中創(chuàng)建一個String對象,那么兩次調(diào)用new String("abc")方法會創(chuàng)建出不同的對象,所以s1==s2 返回false . equals()方法不用說了..
同樣.你也可以利用Integer試試:
Integer i1 = new Integer(1);
Integer i2 = new Integer(1);i1 == i2 同樣返回false. 但是i1.equals();方法會返回true.
下面也是一些方法
比較原始類型的相等與比較兩個對象相等是不同的。如果數(shù)值5存放在兩個不同的int變量中,比較兩個變量是否相等將產(chǎn)生結(jié)果為 boolean 值 true:
public class TestIntComparison {
public static void main(String[] args) {
int x = 5, y = 5;
System.out.println(
"x == y yields " + (x == y));
}
}
TestIntComparison 產(chǎn)生以下輸出:
D:>java TestIntComparison
x == y yields true
相等操作符由于原始類型時比較的是它們的值。而用于對象時比較的是對象的引用而不是對象的實際內(nèi)容。 您可能問:"這些引用都指向同一個對象么?" 為了說明清晰,請看下面只含有 tag 和 age 的 Dog 的又一版本:
class Dog {
int tag;
int age;
public void setTag(int t) {tag=t;}
public void setAge(int a) {age=a;}
}
如果有兩只狗(dog),即使它們的內(nèi)容都相同,用 == 操作符時它們并不相等。下面代碼段的輸出表明在用 "==" 時 a 和 b 并不相等:
Dog a = new Dog();
a.setTag(23129);
a.setAge(7);
Dog b = new Dog();
b.setTag(23129);
b.setAge(7);
if ( a==b ) {
System.out.println("a is equal to b");
}
else {
System.out.println("a is not equal to b");
}