Object类和异常
【要点】
toString方法:将类中要打印的信息转换为自定义格式的打印内容
【返回的是当前对象对应的完整包名.类名@当前对象在内存空间首地址(十六进制)】
equals方法
public boolean equals(Object obj ){}
hashCode方法
有需要的位置一定要加注解
1. Object类
1.1 Object类概述
面向对象语言中都会有一个类是作为所有类的基类,万物之根本!!!Object是Java中所有类的基类,根类。Object类是任何一个类的直接父类或者间接父类。
Object提供了一些可以让任何一个Java中类型使用的方法
toString方法
equals方法
hashCode方法
还存在一些和线程相关的方法:
wait();
notify();
notifyAll();
Object作为一种数据类型,如果按照Java数据类型规范
一个方法需要的参数是Object类型,那么该方法可以传入任何类型
一个方法需要的返回值类型是Object类型,那么该方法的返回值可以是任意类型
【Object定义的数组,可以保存任何Java类型】
【万物皆可Object】
1.2 toString方法[鸡肋]
格式:
public String toString(){}
作用:
返回一个字符串,简要描述当前类对象信息。
【Object原生方法】
Student stu = new Student();
Sout ==> stu
com.qfedu.entity.Student@15db9742
这里就是Object类内toString方法原生效果
【返回的是当前对象对应的完整包名.类名@当前对象在内存空间首地址(十六进制)】
当涉及到类对象需要进行信息简要描述时,toString方法会默认自行调用。
比如:
Sout,信息保存...
【Object原生方法效果问题】
1. 展现信息较少
2. 无法直观的看到类对象中保存的数据
在存在需求的情况下,可以重写toString方法来满足当前类对象简要描述需求。通常情况下,这里不需要手写
使用快捷键直接完成
Alt + Shift + S
==> toString方法重写
package com.qfedu.a_object;
class Dog {
private String name;
private int age;
public Dog() {}
public Dog(String name, int age) {
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Override
public String toString() {
return "Dog [name=" + name + ", age=" + age + "]";
}
}
public class Demo1 {
public static void main(String[] args) {
Dog dog = new Dog("王可可", 5);
System.out.println(dog);
}
}
1.3 equals方法【重点】
1.3.1 equals方法原生概述
格式:
public boolean equals(Object obj){}
作用:
比较两个类对象是否一致,是否是同一个对象,如果是返回true,如果不是返回false
【equals源代码】
在Object类内的原始比较方式:【比较两个对象的空间首地址】
:
public boolean equals(Object obj) {
return (this == obj);
}
this表示调用当前方法的类对象,实际就是一个空间首地址
obj是传入的参数,也是一个引用数据类型,同时也是保存一个空间首地址
【两个对象空间首地址一致,表示同一个对象】
1.3.2 原生equals方法使用瓶颈
package com.qfedu.a_object;
public class Demo2 {
public static void main(String[] args) {
Person person6 = new Person(6, "努尔哈赤", 1500);
Person person7 = new Person(6, "努尔哈赤", 1500);
System.out.println(person5);
System.out.println(person6);
/*
* equals默认比较方式是空间首地址比较,这里person6和person7两个对象
* 都是通过new + 构造方法创建而来,空间首地址是完全不一样的!!!
*
* 但是从代码中可以发现,这里两个对象保存的内容是一致的,对于这样的一种情况
* 其实在开发中还是存在一定的需求的。实际开发中存在需要比较两个对象中保存数据
* 是否一致的情况,这里需要重写equals方法。
*
* equals方法在使用过程中一定要明确调用者是谁。
*/
System.out.println(person6.equals(person7));//false
}
}
1.3.3 equals方法如何重写
思路
1. 判断比较的两个对象是不是同一个对象。
保留原本的this == obj,满足条件直接判断为true
2. 数据类型要求一致。
数据类型必须是一致的情况下才可以进行比较!!!如果equals方法传入参数的数
据类型不是当前调用方法的类对象对应数据类型。没有必要进行比较。
3. 判断【自定义比较】内容
id name age 完全一致,两个对象相同。
【案例代码】
@Override
public boolean equals(Object obj) {
// 比较两个对象的空间首地址,如果两个对象的空间首地址一致,表示是同意个对象,直接返回true
// this 指代的是调用者的地址,obj指代的是传入的对象地址
if (this == obj) {
return true;
}
/*
* 数据类型要求一致
* 需要判断传入的参数类型是否是Person类型,如果不是直接返回false
*
* 使用一个关键字
* instanceOf
* 类对象 instanceOf 类型
* 判断类对象是不是当前指定类型。
*/
if (false == obj instanceof Person) { //可优化为 !(obj instanceof Person)
// 数据类型不一致,直接返回false
return false;
}
// getClass()替代方法
// if (this.getClass() != obj.getClass()) {
// // 数据类型不一致,直接返回false
// return false;
// }
/*
* 按照自定义方式
* 比较对象中保存的数据内容
*
* 我们认为
* Person类型中我们认为 id name age一致才认为是两个相同的对象
*/
// 完成强制转换操作,Object类型转换成当前使用的Person类型操作
// 不强制转化时的obj为父类引用,无法调用Person类对象的属性方法
Person p = (Person) obj;
return this.id == p.id
&& this.age == p.age
/*
* this.name.equals这里执行的是String类equals方法
* 这里在调用方法时需要明确方法的调用者是谁
*
* 这里equals方法是按照字符串比较方式完成的
* name属性同样为引用数据类型,“==”不能比较出两者差异
*/
&& this.name.equals(p.name);
}
1.3.4 equals方法答疑
1. 明确equals方法的调用对象是谁,后期代码中会存在大量同名方法,但是调用对象不一致,效果不一致。
2. 基本数据类型不能使用equals方法
3. 这里存在多态的使用
a. equals方法所需参数是Object类型,不论什么类型数据传入到方法中,都会自动转换为Object类型
b. 方法内instanceOf判断是判断当前传入的对象真实情况,是不是当前操作的Person类型
c. 强制类型转换是在明确数据类型一致的情况下完成的,只有向下强转才能操作成员变量
4. this
this表示调用当前方法的类对象,equals方法调用方式
类对象.equals(另一个类对象)
this表示类对象
1.4 hashCode方法【重点】
1.4.1 hashCode方法原生概述
hash ==> 哈希
hashCode ==> 哈希值
哈希值是对象在开发中的唯一标识!!!
哈希值一般用于一定的哈希结构存储中。
Java中hashCode方法是定义在Object类内,也就是说在Java中任何一个对象都有hashCode方法,可以获取当前对象的哈希值。
Object类内默认的哈希值是当前对象的空间首地址 十进制展示方式
1.4.2 Java开发语法规定
Java中规定:
如果Java中的两个对象使用equals方法比较结果为true,表示相同的对象,那么要求当前比较的两个对象对应的hashCode是一致的。
有且只重写equals方法的情况下,hashCode方法返回的数据依然是对象对应的空间首地址十进制展示方式,如果两个对象按照自定义equals方法比较结果为true,存在可能性两个对象hashCode值不一致,这样会导致后期使用的数据结果中,出现一些违背原则的问题。
hashCode方法返回的哈希值,也是当前对象在一定结构内的唯一索引!!!
【代码开发强制规定】
如果按照自己的比较方式重写了equals方法,必须重写hashCode方法,来满足要求。
1.4.3 如何重写hashCode方法
格式:
public int hashCode();
返回值为int类型
一般要求:
1. 会选择带有一定独立性数据,不可重复性数据作为hashCodo返回数据的首要选择。
2. hashCode在开发中或多或少都有可能出现冲突重复问题,这里尽量避免!!!
【原则】
equals方法比较结果为true,hashCode方法返回哈希一致
1.4.4 属性不存在对应的int类型数据如何解决【小拓展】
情况解释
实体类不存在任何一个int类型数据,不存在唯一性数据。
需要通过成员变量来完成组合操作获取哈希值。
推荐一个方法
Objects工具类提供的hash方法
public static int hash(Object... values) {
return Arrays.hashCode(values);
}
Object...
Object当前方法所需数据类型为Object,也就说支持任何数据类型
... 表示这里参数个数不做任何限制,任意长度,可以没有参数,可以是多个参数
... 不定长参数
指定的数据转换计算之后得到一个具有唯一性的哈希值。
2. 异常处理
2.2 Java中的异常规则
Java中异常和错误的提示机制也是前因后果!!!
都是存在一个最基本的原则,从哪里到哪里
Java中的异常,错题提示已经非常优秀了!!!
TeamViewer
耐心看错误!!!
错误修改有助于提升技术!!!
C语言
段错误!!!
从头到尾去捋逻辑!!
2.3 Throwable类
Throwable是Java中所有异常和错误的基类
--| Error 错误
--| Exception 异常
构造方法:
Throwable();
创建一个Throwable类对象,其中保存的异常或者错误信息为null
Throwable(String message); 【重点】
创建一个Throwable类对象,其中保存的异常或者错误信息为message
成员方法:
String toString();
得到当前异常的简要信息描述
String getMessage();
获取当前Throwable类对象中保存的异常或者错误信息
void printStackTrace(); 【伪重点】
在命令行中展示错误的前因后果!!!红色字体
2.4 Error和Exception
Error 错误
无法处理,只能避免!!!
错误都是Error结尾
Exception 异常
可以处理,还有挽回的余地
异常都是Exception结尾
Java代码中有一个数组需要申请64GB内存,(目前电脑内存32GB)
不可能!!!错误 Error
Java中代码需要一个数组,但是比给予操作的数组不合法
可以处理的,Exception