Java核心技术第五章——2.Object类
Object类:所有类的超类
Object类是Java中所有类的始祖,在Java中每个类都是由它扩展而来的。但是并不需要这样写:
public class Emloyee extends Object
如果没有明确的指出超类,Object就被认为是这个类的超类。在Java中,只有基本数据类型不是对象,所有数组类型,不管是对象数组还是基本类型的数组都扩展(继承)了Object类。
1.equals方法
Object类中的equals方法用于检车一个对象是否等于另外一个对象。也就是说是否具有相同的引用。当时这种判断相同引用一般来说并没有什么luan用。一般只需要两个对象的状态相等,就认为这两个对象时相等的。
public class Employee{ private double salary; private LocalDate hireDay; public boolean equals(Object otherObject){
if(this == otherObject) return true; //是否为相同引用 if(otherObject==null) return false; if(this.getClass() != otherObject.getClass()) return false; //是否属于同一个类 Employee other = (Employee)otherObject;//实例化同一个类则强转 return salary==other.salary&&hireDay.equals(other.hireDay);//判断值是否一致。
} }
2.相等测试与继承
Java语言规范要求equals方法具有下面的特性:
1.自反性:对于任何非空引用x,x.equals(x)返回true
2.对称性:对于任何引用x和y,当且仅当y.equals(x)返回true,x.equals(y)也应该返回true.
3.传递性:对于任何引用x、y和z,如果x.equals(y)返回true,y.equals(z)返回true,x.equals(z)也应该返回true
4.一致性:如果x和y引用的对象没有发生任何改变,返回调用x.equals(y)应该返回同样的结果。
5.对于任何的非空引用x,x.equals(null)应该返回false。
然而利用只getClass检测,是不符合置换原则的。这是因为没有任何一个子类需要重新定义集合是否相等的语义(重新定义equals方法)。在Object中的equals方法没有被声明为final,这样做,可以让子类选择更加有效的算法对集合进行是否相等的检测(重写equals方法)。
如果子类能够拥有自己的相等概念(equals方法在子类中定义),则对称性需求将强制采用getClass进行检测。
如果由超类决定相等的概念(equals方法在父类中定义),那么久可以使用instanceof进行检测。这样就可以在不同子类的对象之间进行相等的比较。(比较的域只能是父类的数据域)
一个比较完善的equals方法:
1.方法参数命名为otherObject 类型为Object,稍后用到。
2.判断是否为同一引用,如果相同返回true。
3.判断是否为Null,如果为Null则返回false;
4.判断是否为同一个类或同一个父类,判断是否为同一个类时则需要在每个子类中定义equals方法(使用getClass方法判断)。
如果判断是否为同一个父类,那么相等时只能使用到父类的equals方法(使用instanceof方法)。
5.强制类型转换otherObject引用为需要判断的类型。
6.判断基本数据类型域和对象域是否都一致。一致返回true.
3.hashCode方法
散列码(hash code)是由对象导出的一个整型值。散列码是没有规律的。如果x和y是两个不同的对象,x.hashCode()和y.hashCode()基本上不会相同。例:
String s = "OK";
StringBuilder sb = new StringBuilder(s);
System.out.println(s.hashCode() + " " + sb.hashCode()); String t = new String("OK");
StringBuilder tb = new StringBuilder(t);
System.out.println(t.hashCode() + " " + tb.hashCode());
2524 1376400422
2524 418304857
此处s和t拥有相同的散列码,这是因为字符串的散列码是由内容导出的。即内容相同,hashCode值相同。
而StringBuffer类中没有定义hashCode方法,是因为它的散列码是由Object类的默认hashCode方法导出的对象存储地址。所以即对象不同,则hashCode值不同。
注意:如果重新定义Equals方法后,hashCode也必须重新定义。保证x.equals(y)返回true,x.hashCode就必须和y.hashCode()的值一致。
4.toString方法
在Objcet中有一个重要的方法,就是toString方法,它用于返回表示对象值得字符串。而Objcet中的toString方法打印的是类名和散列码值。一般比较少用。
public String toString() {
return getClass().getName() + "@" + Integer.toHexString(hashCode());
}
而自定义的实体类,一般都会重写toString方法。而重写的toString方法用方括号把域值括起来。例:
public String toString() {
return getClass().getName()+"{" +
"salary=" + salary +
", hireDay=" + hireDay +
'}';
}
如果是子类的程序员定义自己的toString方法,并将子域添加进去。那么子类增加super.toString即可。
若类域包含数组类型的。那么使用toString方法将会把数组打印成类名@散列码。是因为数组继承了Object的toString方法。
解决方法:一维数组使用Arrays.toString(数组引用),多维数组使用Arrays.deepToString(数组引用)。
个人提倡使用lombok插件。不需要写set、get、toString方法。更详细的lombok插件解释请自行上网搜索。
若小弟写的有什么不足之处,请在评论区评论或至邮箱821312534@qq.com。Thanks♪(・ω・)ノ
Java核心技术第五章——2.Object类的更多相关文章
- Java核心技术第五章——1.类、超类、子类(2)
继上一篇Java核心技术第五章——1.类.超类.子类(1) 6.重载解析 假如调用ClassName.Method(args) 1.编译器列出类ClassName所有名为Method的方法. 2.编译 ...
- [Java核心技术]第四章-对象与类(4.1-4.6总结)
4.1面向对象程序设计概述 OOP(面向对象编程Object Oriented Programming) OOP中数据第一位,算法第二位. 类 封装:关键在于不能让其他方法直接访问类的实例域,程序仅通 ...
- Java核心技术第五章——1.类、超类、子类(1)
1.定义子类: 关键字extends表明正在构造的新类派生与一个已存在的类.已存在的类称为超类.基类或父类:新类称为子类.派生类或孩子类.超类和子类是Java程序员最常用的两个术语(emmm~~我觉得 ...
- JAVA之旅(九)——Object类,equals,toString,getClass,内部类访问规则,静态内部类,内部类原则,匿名内部类
JAVA之旅(九)--Object类,equals,toString,getClass,内部类访问规则,静态内部类,内部类原则,匿名内部类 天天被一些琐事骚扰,学习还得继续 一.Object类 Obj ...
- “全栈2019”Java多线程第五章:线程睡眠sleep()方法详解
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java多 ...
- “全栈2019”Java异常第五章:一定会被执行的finally代码块
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java异 ...
- “全栈2019”Java第九十五章:方法中可以定义静态局部内部类吗?
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...
- “全栈2019”Java第十五章:Unicode与转义字符
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...
- “全栈2019”Java第二十五章:流程控制语句中循环语句while
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...
随机推荐
- 思维导图软件比较-FREEMIND,XMIND,Mindjet Mindmanager
https://www.zhihu.com/question/22094277
- 值得注意的CSS属性
文本TEXT letter-spacing 字符间距 word-spacing 字间距 line-height 行高 text-decoration 修饰(下划线) text-indent 首行缩进 ...
- python assert的作用
使用assert断言是学习python一个非常好的习惯,python assert 断言句语格式及用法很简单.在没完善一个程序之前,我们不知道程序在哪里会出错,与其让它在运行最崩溃,不如在出现错误条件 ...
- LinkedBlockingQueue简介
LinkedBlockingQueue是一个单向链表实现的阻塞队列,先进先出的顺序.支持多线程并发操作. 相比于数组实现的ArrayBlockingQueue的有界,LinkedBlockingQue ...
- 【BZOJ 3697】采药人的路径
题目链接: TP 题解: 调了好久233. 大概想一想就是树分,然后考虑这样路径(u,v)的特征,以根节点(root)切开,u到root的阴阳差值,和v到root巧合互为相反数,然后考虑要有一个点可作 ...
- bzoj 1210 [HNOI2004] 邮递员 插头dp
插头dp板子题?? 搞了我一晚上,还tm全是抄的标程.. 还有高精,哈希混入,还是我比较弱,orz各种dalao 有不明白的可以去看原论文.. #include<cstdio> #incl ...
- BZOJ_3261_最大异或和_可持久化trie
BZOJ_3261_最大异或和_可持久化trie Description 给定一个非负整数序列{a},初始长度为N. 有M个操作,有以下两种操作类型: 1.Ax:添加操作,表示在序列末尾添加一个数x, ...
- 深入css布局篇(3)完结 — margin问题与格式化上下文
深入css布局(3) - margin问题与格式化上下文 在css知识体系中,除了css选择器,样式属性等基础知识外,css布局相关的知识才是css比较核心和重要的点.今天我们来深入学习一下 ...
- ALS交替最小二乘法总结
摘要: 1.算法概述 2.算法推导 3.算法特性及优缺点 4.注意事项 5.实现和具体例子 6.适用场合 内容: 1.算法概述 ALS是alternating least squares的缩写 , 意 ...
- ActiveMQ详解
Apache ActiveMQ介绍 使用MQ的场景 ActiveMQ的安装 收发消息的简单实现 ActiveMQ内部实现 queue和topic 消息持久化 kahadb原理 最关键的6个配置 Apa ...