首先来说一下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的方法表示终结,不能被重写~即方法的作用功能不能进行修改