jdk源码Object类解析
一 简介
java.lang.Object,是Java所有类的父类,在你编写一个类的时候,若无指定父类(没有显式extends一个父类),会默认的添加Object为该类的父类。
在JDK 6之前是编译器
处理,即编译后的zclass字节码可以显示的看到 extends Object.
JDK 7之后是虚拟机
处理,class字节码已经看不到了,虚拟机执行代码会默认添加Object类为父类。
我们在编辑器
里(IDE)打点时就能列出Object类下的方法,此时还没轮到编译器和jvm,编辑器就已经知道MyClass类的父类是Object类了,这是因为编辑器为我们做了一些智能处理.
二 代码解析
public class Object {
//native修饰的方法都是本地方法,即在C/C++在DLL中已经实现,通过JNI调用
private static native void registerNatives();
//类初始化调用此方法
static {
registerNatives();
} /**
* Constructs a new object.
*/
@HotSpotIntrinsicCandidate
public Object() {} /**
* 返回此Object的运行时类(每个类的Class类对象)
* 每一个类在被加载的时候,都会生成一个Class类实例,
* 而这个方法就可以在运行时期获得对象(这里的对象是堆里的那个对象,也就是获得的是动态类型的那个类)的Class对象,Class对象主要用于反射。
*/
@HotSpotIntrinsicCandidate
public final native Class<?> getClass(); /**
* 这个方法返回对象的哈希码值,这个方法与哈希表的性能有关,它的实现方法是通过将对象在内存中所处于的位置转换成数字,这个数字就是hashCode
*/
@HotSpotIntrinsicCandidate
public native int hashCode(); /**
* 对比两对象的内存地址,如果不重写,equals方法比较的是对象地址
* 判断其它对象是否与此对象“相等”;如果一个对象要重写这个方法,需要与其它非空对象满足等价关系:以下的x,y,z均为非空对象
* (1)自反性,x.equals(x)=true;
* (2)对称性,x.equals(y) = y.equals(x);
* (3)传递性,若x.equals(y) = true,y.equals(z) = true,则x.equals(z) = true;
* (4)一致性,只要equals的比较操作在对象中所用的信息没有被修改,多次调用x.equals(y)就会一致地返回相同结果;
* (5)x.equals(null) = false;
* 注意: 当重写equals方法时,也要重写hashCode方法,这是为了确保相等的对象有相同的哈希码值
*/
public boolean equals(Object obj) {
return (this == obj);
} /**
* protected方法,子类可重写,创建并返回此对象的一个副本。
* 所有的数组都被视为实现接口 Cloneable,且 数组类型T[]的 clone方法返回的类型是T[] ,T 可以是任何引用或基本类型
* 一个类只有实现了Cloneable接口(标记接口,无任何内容,只针对clone方法),才可以在该类的实例上调用clone方法,否则会抛出CloneNotSupportException。
* Object中默认的实现是一个浅拷贝,也就是表面拷贝,如果需要实现深层次拷贝的话,必须对类中可变域生成新的实例
*/
@HotSpotIntrinsicCandidate
protected native Object clone() throws CloneNotSupportedException; /**
* 返回对象的的字符串表示,默认是:类名+@+此对象哈希码的无符号十六进制表示组成,即值等于:getClass().getName() + '@' + Integer.toHexString(hashCode())
*/
public String toString() {
return getClass().getName() + "@" + Integer.toHexString(hashCode());
} /**
* 唤醒在此对象监视器上等待的线程,如果有多个,随机选择一个
*/
@HotSpotIntrinsicCandidate
public final native void notify(); /**
* 唤醒在此对象监视器上等待的所有线程
*/
@HotSpotIntrinsicCandidate
public final native void notifyAll(); /**
* final修饰,不可重写,永久等待,直到被唤醒
*/
public final void wait() throws InterruptedException {
wait(0L);
} /**
* 本地已实现方法,在其他线程调用此对象的 notify() 方法或 notifyAll() 方法前,导致当前线程等待
* 在超过给定参数 timeoutMillis 时间之前会一直等待,可提前被唤醒,即等个最大等待时间,如果是0 则永久等待
*/
public final native void wait(long timeoutMillis) throws InterruptedException; /**
* 与上面方面相同,但是可以精确控制时间到 毫微妙级别
* timeoutMillis - 毫秒
* nanos - 毫微妙
* 1秒=1000豪秒 1毫秒=1000微秒 1微秒=1000毫微秒
*/
public final void wait(long timeoutMillis, int nanos) throws InterruptedException {
if (timeoutMillis < 0) {
throw new IllegalArgumentException("timeoutMillis value is negative");
}
if (nanos < 0 || nanos > 999999) {
throw new IllegalArgumentException(
"nanosecond timeout value out of range");
}
if (nanos > 0) {
timeoutMillis++;
}
wait(timeoutMillis);
} /**
* finalize()是Object的protected方法,子类可以覆盖该方法以实现资源清理工作,GC在回收对象之前调用该方法,jdk9之后已被废弃
* 一个对象只会调用一次
*/
@Deprecated(since="9")
protected void finalize() throws Throwable {}
}
jdk源码Object类解析的更多相关文章
- 2018-08-27 使用JDT核心库解析JDK源码后初步分析API命名
源自术语词典API项目 · Issue #85 · program-in-chinese/overview, 打算先用早先的代码提取JDK API中的类/方法/参数名, 看看有哪些词需要翻译. 源码在 ...
- JDK源码学习笔记——Object
一.源码解析 public class Object { /** * 一个本地方法,具体是用C(C++)在DLL中实现的,然后通过JNI调用 */ private static native void ...
- Java中集合框架,Collection接口、Set接口、List接口、Map接口,已经常用的它们的实现类,简单的JDK源码分析底层实现
(一)集合框架: Java语言的设计者对常用的数据结构和算法做了一些规范(接口)和实现(实现接口的类).所有抽象出来的数据结构和操作(算法)统称为集合框架. 程序员在具体应用的时候,不必考虑数据结构和 ...
- 设计模式-简单工厂Coding+jdk源码解析
感谢慕课geely老师的设计模式课程,本套设计模式的所有内容均以课程为参考. 前面的软件设计七大原则,目前只有理论这块,因为最近参与项目重构,暂时没有时间把Coding的代码按照设计思路一点点写出来. ...
- 从JDK源码角度看Object
Java的Object是所有其他类的父类,从继承的层次来看它就是最顶层根,所以它也是唯一一个没有父类的类.它包含了对象常用的一些方法,比如getClass.hashCode.equals.clone. ...
- JDK源码阅读(三):ArraryList源码解析
今天来看一下ArrayList的源码 目录 介绍 继承结构 属性 构造方法 add方法 remove方法 修改方法 获取元素 size()方法 isEmpty方法 clear方法 循环数组 1.介绍 ...
- JDK源码阅读(一):Object源码分析
最近经过某大佬的建议准备阅读一下JDK的源码来提升一下自己 所以开始写JDK源码分析的文章 阅读JDK版本为1.8 目录 Object结构图 构造器 equals 方法 getClass 方法 has ...
- Integer.parseInt不同jdk源码解析
执行以下代码: System.out.println(Integer.parseInt("-123")); System.out.println(Integer.parseInt( ...
- 结合JDK源码看设计模式——原型模式
定义: 指原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象.不需要知道任何创建的细节,不调用构造函数适用场景: 类初始化的时候消耗较多资源 new产生的对象需要非常繁琐的过程 构造函数比较 ...
随机推荐
- Linux(Centos)安装node及anyproxy
一.安装node //下载 wget https://nodejs.org/dist/v10.9.0/node-v10.9.0-linux-x64.tar.xz //解压 tar xf node-v1 ...
- ant design 的Table组件固定表头时不对齐
现在有一个表格,里面的列数是不固定的(可以重复写入数据),且列数行数都可能很多,就带来一个问题: 必须要固定表头,但是antd 的表格组件设置了固定表格 scroll={{x:1000,y:300}} ...
- [Ljava.lang.String;@3e5084c9:是一个字符串数组的字节码表示
[Ljava.lang.String;@3e5084c9:是一个字符串数组的字节码表示 打印一个字符串数组的话,会发现 String[] arr = new String[10]; // String ...
- DEVOPS技术实践_02:jenkins自动构建项目
一.用户名密码错误 打开jenkins发现用户名密码错误,解决 1.1 找到config.xml文件 [root@jenkins-master ~]# ll -a drwxr-xr-x. root r ...
- 为什么在做微服务设计的时候需要DDD?
记得之前在规划和设计微服务架构的时候,张队长给了我一个至今依然记忆深刻的提示:『你的设计蓝图里为什么没有看到DDD的影子呢?』 随着对充血模型的领域认知的加深,我越加感觉到DDD的重要性.但是DDD内 ...
- 写代码 Log 也要认真点么?
Log自然是需要的, 尤其是正式的产品; 但如果只是自己或内部用用的小工具, 也需要认真点吗? 实话说, 自己对 log 总是不上心, 总觉得调试好了, 能跑了, 足以. 所以, 被大妈怼了好几次 l ...
- 「Luogu P1210」回文检测 解题报告
题面 这是一道诡异的黄题 居然让你求一串吧啦吧啦的东西中 字母(大小写)最长的回文串的长度,还要输出完整的串 吐血 思路: 保持淡定,我们啥都不会,就会Manacher,那就用Manacher大法! ...
- Codeforces Round #612 (Div. 2) 前四题题解
这场比赛的出题人挺有意思,全部magic成了青色. 还有题目中的图片特别有趣. 晚上没打,开virtual contest打的,就会前三道,我太菜了. 最后看着题解补了第四道. 比赛传送门 A. An ...
- Good Bye 2019(前五题题解)
这套也是后来补得. 我太菜了,第三题就卡着了.想了好久才做出来,要是参加了绝对掉分. D题是人生中做完的第一道交互题,不容易. 比赛传送门 A.Card Game 题目大意:一共有n张互不相同的牌,玩 ...
- Spark设置Kryo序列化缓冲区大小
背景 今天在开发SparkRDD的过程中出现Buffer Overflow错误,查看具体Yarn日志后发现是因为Kryo序列化缓冲区溢出了,日志建议调大spark.kryoserializer.buf ...