前言:重新学习下jdk源码,通过一行一行解读jdk源码,得到进一步的提升,为学好上层应用打下扎实基础。
java.lang.Object
java.lang包下的类不需要导入
java中的两种导包方式:
- 单类型导入 —— 例如import java.util.Date
- 按需类型导入 —— 例如import java.util.*
编程所使用的各种工具都是按照单类型导包,需要什么类导入什么包,而按需类型导入是按照需求导入并不是导入整个包下的所有类。
按需类型导入会影响java代码的编译速度,在编码时最好用单类型导入,避免命名冲突。
编译器会自动导入java.lang包,用的多,提前加载了,省资源。
源码分析
在JDK的Object源码中,看不到构造器,系统会自动添加一个无参构造器。
package java.lang;
public class Object {
private static native void registerNatives();
//类加载的时候执行该方法,通过该方法来注册本地方法
static {
registerNatives();
}
//这个方法的作用是返回对象运行时类,有native修饰,不考虑
public final native Class<?> getClass();
//该方法也用native声明的本地方法,作用是返回对象的散列码,是int类型的数值
public native int hashCode();
//在Object类中,==运算符和equals方法是等价的,都是比较两个对象的引用是否相等
public boolean equals(Object obj) {
return (this == obj);
}
protected native Object clone() throws CloneNotSupportedException;
//getClass().getName()返回对象的全类名,Integer.toHexString(hashCode())以16进制无符号整数返回此哈希码字符串表示
public String toString() {
return getClass().getName() + "@" + Integer.toHexString(hashCode());
}
//notify,notifyAll,wait都是本地final方法,无法被重写
public final native void notify();
public final native void notifyAll();
public final native void wait(long timeout) throws InterruptedException;
//调用该方法后会释放对象的锁
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 > 0) {
timeout++;
}
wait(timeout);
}
public final void wait() throws InterruptedException {
wait(0);
}
//用于垃圾回收,由jvm自动调用
protected void finalize() throws Throwable { }
}