Object類中方法詳解


概述

Object 是類層次結構的根類。每個類都使用 Object 作為超類。所有對象(包括數組)都實現這個類的方法。所有的類都直接或者間接的繼承自Object類。該類的設計也符合面向對象中"萬事萬物皆對象"的思想。

構造方法

public Object()

  • 任何一個類都會調用這個方法,訪問子類構造方法的首先會先訪問父類無參的構造方法。

hashCode方法

int hashCode()

  • 實際上,由 Object 類定義的 hashCode 方法確實會針對不同的對象返回不同的整數。

  • (這一般是通過將該對象的內部地址轉換成一個整數來實現的,但是 JavaTM 編程語言不需要這種實現技巧。)

  • hashCode和地址有關,我們可以理解為地址值,但是不是真實地址值

public class ObjectDemo02 {
       public static void main(String[] args) {
               Student s1 = new Student("老王", 37);
               Student s2 = new Student("老王", 37);  
               System.out.println(s1.hashCode());
               System.out.println(s2.hashCode());
               Student s3 = s1;
               System.out.println(s1 == s2); // false
               System.out.println(s1 == s3); // true
               
       }
}

getClass方法

我們知道在Java中一切都是對象,我們一般所使用的對象都直接或間接繼承自Object類。Object類中包含一個方法名叫getClass,利用這個方法就可以獲得一個實例的class對象。這個對象指的是代表一個類型的對象,因為一切皆是對象,類型也不例外,在Java使用class類的對象來表示一個類型。所有的類型類都是Class類的實例。

A a = new A();

if(a.getClass()==A.class)
System.out.println("equal");
else System.out.println("unequal");

//結果為equal;

因此,獲取類的class對象的兩種方式:

  1. 如果你知道一個實例,那么你可以通過實例的“getClass()”方法獲得該對象的class對象
  2. 如果你知道一個類型(String名稱),那么你可以使用“類名.class”的方法獲得該類型的class對象

toString方法

String toString()
返回類名和hashCode值

源碼:

public String toString() {
       return getClass().getName() + "@" + Integer.toHexString(hashCode());
   }
  • toString返回的是一個 類名全路徑 + @ + hashCode的十六進制
    System.out.println(s1);
  • 輸出語句輸出一個引用類型的時候,默認調用了引用類型的toString方法輸出

equals方法

boolean equals(Object obj)
判斷兩個類的地址是否相等;

源碼:

public boolean equals(Object obj) {
        //      s1 == s2
       return (this == obj);
   }

通過源碼我們發現 Object方法中的equals比較的是地址值。
然而比較兩個對象是否相等,比較地址值毫無意義。我們希望比較兩個對象,比較的是成員變量是否相等,所以說父類Object繼承過來的equals方法不能滿足具體子類Student的需求,所以需要方法重寫。

String類中equals方法:
源碼:

	public boolean equals(Object anObject) {
        if (this == anObject) {
            return true;
        }
        if (anObject instanceof String) {
            String anotherString = (String)anObject;
            int n = value.length;
            if (n == anotherString.value.length) {
                char v1[] = value;
                char v2[] = anotherString.value;
                int i = 0;
                while (n-- != 0) {
                    if (v1[i] != v2[i])
                        return false;
                    i++;
                }
                return true;
            }
        }
        return false;
    }

所以比較兩個字符串是否相等比較的是每一個字符是否相等。
因為字符串類重寫equals方法。
如果我們自己寫的類不重寫equals方法,那么比較的是地址值是否相等。

在開發中一般用自動生成
alt+shift+s 再按H
通過觀察自動生成的代碼我們發現字符串比較的是內容是否相等

clone方法

protected Object clone()
創建並返回此對象的一個副本

使用時注意異常:java.lang.CloneNotSupportedException
異常:克隆不支持異常
原因:需要克隆的類沒有實現克隆接口。
解決:找到要克隆的類實現Cloneable接口。

public class Test {
	public static void main(String[] args) throws CloneNotSupportedException {
		TestClone t = new TestClone("張三",29);
		TestClone l = new TestClone("李四",33);
		Object tClone = t.clone();
		TestClone tc = (TestClone)tClone;
		System.out.format("%-4s"+"%d",tc.name,tc.age);
	}
}
class TestClone extends Object implements Cloneable{
	String name;
	int age;
	public Object clone() throws CloneNotSupportedException{
		return super.clone();
	}
	public TestClone(){}
	public TestClone(String name, int age) {
		super();
		this.name = name;
		this.age = age;
	}
}
		//輸出:張三	29

finalize方法

protected void finalize()

  • 當垃圾回收器確定不存在對該對象的更多引用時。
  • 由對象的垃圾回收器調用此方法。用於垃圾回收,但是什么時候回收不確定。

一般有兩中情況對象會被作為垃圾對象:

  1. 當對象被賦null
Student s = new Student();
        s = null;
  1. 當對象重新被創建
Student s = new Student();        
        s = new Student();

注意點:
finalize()方法,finally關鍵字,final關鍵字的區別?

  • finalize()方法

當垃圾回收器確定不存在對該對象的更多引用時, 由對象的垃圾回收器調用此方法。用於垃圾回收,但是什么時候回收不確定。

  • final

final修飾的變量表示常量,不能夠被二次賦值 。
final修飾的類不能夠被繼承 。
final修飾的方法不能夠被子類重寫。

  • finally

Java 中的 Finally 關鍵一般與try一起使用,在程序進入try塊之后,無論程序是因為異常而中止或其它方式返回終止的,finally塊的內容一定會被執行 。
特殊情況:在執行到finally之前jvm退出了(比如System.exit(0))。
作用:用於釋放資源,在IO流操作和數據庫操作中常見到。

以上


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM