Java操作符易混淆點你解決了么?
今天開始重新溫習Java,翻了翻java編程思想,看到操作符那里有一些考試面試經(jīng)常遇到的又容易出錯的地方,在這記錄一下。
1. 賦值操作:在對一個對象進行賦值操作時,我們所操作的是對對象的引用。比如使用c=d,將對象d賦給對象c,這時c所指向的正式d之前所指向的內存,這時如果改變c或者d其中任何一個的值,另外一個的值也會變。
下面舉個例子說明:
Java代碼
- 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作為參數(shù)傳遞給函數(shù)f,并在函數(shù)f中對對象a進行修改,那么實際修改的是a對象本身,因為傳遞給f的是a的一個引用,它和a指向的是同一塊內存。
Java代碼
- 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。
舉個例子:
Java代碼
- 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。
【編輯推薦】