java操作符易混淆點
今天開始重新溫習java,翻了翻java程式設計思想,看到操作符那裡有一些考試面試經常遇到的又容易出錯的地方,在這記錄一下。
1. 賦值操作:在對一個物件進行賦值操作時,我們所操作的是對物件的引用。比如使用c=d,將物件d賦給物件c,這時c所指向的正式d之前所指向的記憶體,這時如果改變c或者d其中任何一個的值,另外一個的值也會變。
下面舉個例子說明:
class A{ int a; } public class Test{ public static void main(String[] args){ A c = new A(); A d = new A(); c.a = 10; d.a = 15; c = d; System.out.println("c.a = " + c.a + ", d.a = " + d.a); d.a = 20; System.out.println("c.a = " + c.a + ", d.a = " + d.a); } }
輸出結果為:
c.a = 15, d.a = 15
c.a = 20, d.a = 20
可見當d的值改變時,c的值也會跟著改變,這說明這兩個物件指向同一塊兒記憶體。
2. 方法呼叫中的別名問題,比如將物件a作為引數傳遞給函式f,並在函式f中對物件a進行修改,那麼實際修改的是a物件本身,因為傳遞給f的是a的一個引用,它和a指向的是同一塊記憶體。
class A{ int item; } public class Test{ public static void main(String[] args){ A a = new A(); a.item = 10; f(a); System.out.println("a.item = " + a.item); } static void f(A obj){ obj.item = 20; } }
輸出結果為:
a.item = 20
3. equals 和 ==
==就是用來比較物件的引用,也就是說它只在乎兩個物件是不是指向同一塊記憶體,如果是的話,就返回true,否則即使兩個物件的值相等,它也返回false
equals()的預設行為也是比較引用,但是它在jdk的許多類中都被覆蓋過了(這些類有java.io.file,java.util.Date,java.lang.string,包裝類(Integer,Double等)),覆蓋後的結果為,只要兩個物件的型別一致、值一致,就返回true,否則返回false。
舉個例子:
class A{ int item; } public class Test{ public static void main(String[] args){ A a = new A(); a.item = 10; A b = new A(); b.item = 10; f(a, b); a = b; f(a, b); String s1 = new String("test"); String s2 = new String("test"); if(s1 == s2) System.out.println("s1 == s2"); else if(s1.equals(s2)) System.out.println("s1 equals s2"); } static void f(A a, A b){ if(a == b) System.out.println("a == b"); else System.out.println("a != b"); if(a.equals(b)) System.out.println("a equals b"); else System.out.println("a is not equals b"); } }
輸出結果為:
a != b
a is not equals b
a == b
a equals b
s1 equals s2
這充分說明了 == 和 equals都是比較物件的引用的,s1 equals s2說明了在String類裡覆蓋了equals方法,只要兩個物件值一樣,就返回true。