首页 > 代码库 > 【小白的java成长系列】——顶级类Object源码分析

【小白的java成长系列】——顶级类Object源码分析

首先来说一下api文档使用,api这个词对有一定开发经验的java编程人员来说是很喜爱的~

java当然也提供了api开发文档,下载地址:http://www.oracle.com/technetwork/java/javase/downloads/index.html 找到下面的:


下载自己喜爱的版本即可,解压,点击~/jdk-7u60-apidocs/api/index.html就可以查看其api了:


跟上网一样一样的,点击相应链接就可以查看其信息了。


进入正题,说说Object这个类:

先奉上去掉注释的源码:可以看到这里面出现了很多native关键字,这个前面也有介绍,它是调用本地的方法,这边说得直白一点,就是调用jvm底层的方法,也是C/C++方法的,我们知道,jvm很大程度上是依赖于C/C++开发出来的~

package java.lang;

public class Object {

	private static native void registerNatives();

	static {//静态块,默认调用registerNatives()方法
		registerNatives();
	}
<span style="white-space:pre">	</span>//返回运行时的Class,一般在反射过程中用的比较多
	public final native Class<?> getClass();

<span style="white-space:pre">	</span>//得到jvm运行时的hash值
	public native int hashCode();

<span style="white-space:pre">	</span>//比较方法,两个对象进行比较
	public boolean equals(Object obj) {
		return (this == obj);
	}

<span style="white-space:pre">	</span>//克隆方法
	protected native Object clone() throws CloneNotSupportedException;
<span style="white-space:pre">	</span>
<span style="white-space:pre">	</span>//转换成String,这个就说明了为什么我们在打印对象的时候,控制台会看到xx@xxx的信息,其实是调用的是这个方法
	public String toString() {
		return getClass().getName() + "@" + Integer.toHexString(hashCode());
	}

<span style="white-space:pre">	</span>//唤醒线程,即唤醒某个处于睡眠的线程——>对象的线程
	public final native void notify();

<span style="white-space:pre">	//唤醒</span>线程<span style="white-space:pre">,即唤醒</span>所有<span style="white-space:pre">处于睡眠的</span>线程<span style="white-space:pre">——>对象的</span>线程
	public final native void notifyAll();

<span style="white-space:pre">	</span>//线程休眠等待
	public final native void wait(long timeout) throws InterruptedException;

<span style="white-space:pre">	</span>//线程休眠等待
	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);
	}

<span style="white-space:pre">	</span>//线程休眠等待
	public final void wait() throws InterruptedException {
		wait(0);
	}

<span style="white-space:pre">	</span>//GC回收(垃圾回收)收尾工作
	protected void finalize() throws Throwable {
	}
}
解释如上,会有以下一些问题:

1、为什么会用到native这个词?

这个还真不好回答,先来介绍java的一门技术——JNI(Java Native Interface),这个的出现很大程度上是丰富了java语言的,它允许java语言调用其他语言的东东,有一些java不好实现的东东,就可以使用其他语言进行实现,然后供给java调用。上面出现这么多native方法,说得难听一点就是java实现不了的功能,在JVM层次使用了C\C++实现了,丰富了java应用层的api。

2、finalize()方法?

这个是要跟GC结合来说明,后面会重点介绍~

3、很多方法声明为final?

声明为final的方法表示终结,不能被重写~即方法的作用功能不能进行修改