1. 程式人生 > >java操作符易混淆點

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。