Java语言不同于C++语言,是一种单继承结构语言,也就是说,Object类是所有类的父类,位于java.lang包中。(PS:任何类的对象,都可以调用Object类中的方法,包括数组对象。)
object类的结构
Object类有12个成员方法,按照用途可以分为以下几种:
1)构造函数
2)hashCode和equale函数用来判断对象是否相同,
3)wait(),wait(long),wait(long,int),notify(),notifyAll()
4)toString()和getClass
5)clone()
6)finalize()用于在垃圾回收
问:Object和Object[]之间有什么区别?
答:1).方法中的形参是Object类型时,任何类型的参数都可以传进去执行。
2).方法中形参是Object[]类型时,只有对象数组可以传入执行
例:
public static void arrayTest(Object[] obj){
}
public static void main(){
Int[] array = new int[4];
arrayTest(array) //报错
}
问:equals方法与hashCode方法之间有什么关系?
答:
(1)如果两个对象使用equals比较返回true,那么它们的hashCode值一定要相同。
(2)如果两个对象equals比较返回false,那么它们的hashCode值不一定不同。
(3)覆盖equals,往往需要覆盖hashCode,可以使用Eclipse自动生成,保证equals返回true,则hashCode相同;equals返回false,则hashCode不同。
(4)在Set集合部分有实际应用。
函数解释
clone():用来另存一个当前存在的对象,也可以理解为创建并返回此对象的一个副本。
equale():用于确认两个对象是否相同。
finalize():进行垃圾回收的时候会用到,匿名对象回收之前会调用到,当垃圾回收器确定不存在对该对象的更多引用时,由对象的垃圾回收器调用此方法。
getClass():返回一个对象的运行时类。
hashCode():返回该对象的哈希码值(16进制)。
notify():唤醒在此对象监视器上等待的单个线程。
toString() :返回该对象的字符串表示。
wait():导致当前的线程等待,直到其他线程调用此对象的 notify()方法或 notifyAll()方法。
wait(long timeout):导致当前的线程等待,直到其他线程调用此对象的 notify() 方法或 notifyAll() 方法,或者超过指定的时间量。
wait(long timeout, int nanos):导致当前的线程等待,直到其他线程调用此对象的 notify() 方法或 notifyAll() 方法,或者其他某个线程中断当前线程,或者已超过某个实际时间量。
源码解释
package java.lang;
public class Object {
/* 一个本地方法,具体是用C(C++)在DLL中实现的,然后通过JNI调用。*/
private static native void registerNatives();
/* 对象初始化时自动调用此方法*/
static {
registerNatives();
}
/* 返回此 Object 的运行时类。*/
public final native Class<?> getClass();
/*
hashCode 的常规协定是:
1.在 Java 应用程序执行期间,在对同一对象多次调用 hashCode 方法时,必须一致地返回相同的整数,前提是将对象进行 equals 比较时所用的信息没有被修改。从某一应用程序的一次执行到同一应用程序的另一次执行,该整数无需保持一致。
2.如果根据 equals(Object) 方法,两个对象是相等的,那么对这两个对象中的每个对象调用 hashCode 方法都必须生成相同的整数结果。
3.如果根据 equals(java.lang.Object) 方法,两个对象不相等,那么对这两个对象中的任一对象上调用 hashCode 方法不 要求一定生成不同的整数结果。但是,程序员应该意识到,为不相等的对象生成不同整数结果可以提高哈希表的性能。
*/
public native int hashCode();
public boolean equals(Object obj) {
return (this == obj);
}
/*本地CLONE方法,用于对象的复制。*/
protected native Object clone() throws CloneNotSupportedException;
/*返回该对象的字符串表示。非常重要的方法*/
public String toString() {
return getClass().getName() + "@" + Integer.toHexString(hashCode());
}
/*唤醒在此对象监视器上等待的单个线程。*/
public final native void notify();
/*唤醒在此对象监视器上等待的所有线程。*/
public final native void notifyAll();
/*在其他线程调用此对象的 notify() 方法或 notifyAll() 方法前,导致当前线程等待。换句话说,此方法的行为就好像它仅执行 wait(0) 调用一样。
当前线程必须拥有此对象监视器。该线程发布对此监视器的所有权并等待,直到其他线程通过调用 notify 方法,或 notifyAll 方法通知在此对象的监视器上等待的线程醒来。然后该线程将等到重新获得对监视器的所有权后才能继续执行。*/
public final void wait() throws InterruptedException {
wait(0);
}
/*在其他线程调用此对象的 notify() 方法或 notifyAll() 方法,或者超过指定的时间量前,导致当前线程等待。*/
public final native void wait(long timeout) throws InterruptedException;
/* 在其他线程调用此对象的 notify() 方法或 notifyAll() 方法,或者其他某个线程中断当前线程,或者已超过某个实际时间量前,导致当前线程等待。*/
public final void wait(long timeout, int nanos) throws InterruptedException {
if (timeout < 0) {
throw new IllegalArgumentException("timeout value is negative");
}
if (nanos < 0 || nanos > 999999) {
throw new IllegalArgumentException(
"nanosecond timeout value out of range");
}
if (nanos >= 500000 || (nanos != 0 && timeout == 0)) {
timeout++;
}
wait(timeout);
}
/*当垃圾回收器确定不存在对该对象的更多引用时,由对象的垃圾回收器调用此方法。*/
protected void finalize() throws Throwable { }
}
(源码解释部分是转自:点击打开链接)
整理不易...