当前位置:首页 » 《随便一记》 » 正文

Java中的【Object类】

27 人参与  2023年03月31日 10:43  分类 : 《随便一记》  评论

点击全文阅读


目录

?1.Object类是什么?

?2.Object类中的equals方法

?3.Object类中的hashCode方法

?4.编译器自动生成equals和hashCode


?1.Object类是什么?

?Object 是 Java 类库中的一个特殊类,也是所有类的父类

也就是说,Java 允许把任何类型的对象赋给 Object 类型的变量。

?Java里面除了Object类,所有的类存在继承关系的。

?Object 类位于 java.lang 包中,编译时会自动导入, 当一个类被定义后,如果没有指定继承的父类,那么默认父类就是 Object 类。

class Person {}class Student {}public class Test03 {    public static void func(Object o) {  }    public static void main(String[] args) {        func(new Person());        func(new Student());    }    public static void main1(String[] args) {        Object o = new Person();        Object o2 = new Student();    }}

下面来看一下Object类中都有什么方法

 本篇会简单介绍hashCode(),equals()

?2.Object类中的equals方法

下面看这样一段代码

class Person {    public String dz;    public Person(String dz) {        this.dz = dz;    }    @Override    public String toString() {        return "Person{" +                "dz='" + dz + '\'' +                '}';    }}class Student {}public class Test03 {    public static void main(String[] args) {        Person person = new Person("beijing");        Person person1 = new Person("beijing");        System.out.println(person == person1);}

 如果直接这样比较,看地址是否相同,就会输出false,输出是错误的

⚜️那么如果要比较,有什么方法吗

?在java中提供了一个方法是equals,可以用来比较两对象是否相同

   System.out.println(person.equals(person1));

如果直接在main中这样写,还是会输出false,

这是因为person里面没有equals,默认是继承于Object的

 可以看到里面比较的还是this和obj,也就是当前传进来的参数,所以才是false。

⚜️那么如何用equals进行比较

?那就要重写一个equals才可以进行比较

    @Override    public boolean equals(Object obj) {        //判断当前obj参数是否为null        if (obj == null) {            return false;        }        if (this == obj) {            return true;        }        //不是Person类对象        if (!(obj instanceof Person)) {            return false;        }        Person ret = (Person) obj;        return this.dz.equals(ret.dz);    }

?我们可以String帮助重写equals了

 此时equals就可以比较了

 

?比较对象中内容是否相同的时候 要重写equals


?3.Object类中的hashCode方法

?使用hashCode可以计算具体的对象位置,也就是内存地址,然后调Integer.toHexString()方法,将这个地址以16进制输出

 

? 两个dz是相同的,然后直接用hashCode计算内存地址,然后代码发现,内存地址是不同的

说明直接这样中hashCode是不行的,那就要重新实现一个hashCode,

 下面重写一下hashCode,

    @Override    public int hashCode() {        return Objects.hash(dz);    }

然后运行代码试试看,果然重写之后,内存地址相同了

 ?所以,hashCode是用来定位 位置的

 


?4.编译器自动生成equals和hashCode

一般重写时,都是这两个同时进行重写

这就是生成好了的 equals和hashCode

    @Override    public boolean equals(Object o) {        if (this == o) return true;        if (o == null || getClass() != o.getClass()) return false;        Person person = (Person) o;        return Objects.equals(dz, person.dz);    }


点击全文阅读


本文链接:http://zhangshiyu.com/post/57521.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

关于我们 | 我要投稿 | 免责申明

Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1