JAVA API | Object类

本文详细解释了Java中的`toString()`方法如何被隐藏并重写以提供更易读的对象描述,`equals()`方法的默认行为和如何重写以比较对象内容,以及`clone()`方法的使用限制和重写过程。此外,还提到IDEA中自动生成equals方法的便捷方式。
摘要由CSDN通过智能技术生成

1. toString()

说明:返回对象的字符串表示式。

首先,我们创建一个Student类:

public class Student {
    private String name;
    private int age;

    public Student() {
    }

    public Student(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;
    }
}

接着,我们在Main类中放入如下代码:

public class Test {
    public static void main(String[] args) {
        Student s1 = new Student("赵敏",23);
        System.out.println(s1);
    }
}

在上面的案例中,我们将s1打印出来了:

事实上,这里的System.out.println(s1);就是使用了toString这个方法,只是被隐藏了,他的全写应该为:

System.out.println(s1.toString());

补充一下,我们在这里可以对toString进行重写,让他更加易懂:

@Override 
public String toString() {
    return "Student{" +
            "name='" + name + '\'' +
            ".age =" + age +
            '}';
}

这样,他返回的内容将更加易懂:

2. equals(Object o)

说明:用于判断两个对象是否相等。

例如下面的代码中:

public class Test {
    public static void main(String[] args) {
        Student s1 = new Student("赵敏",23);
        System.out.println(s1);

        Student s2 = new Student("赵敏",23);
        System.out.println(s2.equals(s1));
    }
}

可以看到,s1和s2的内容是相等的,但是s2.equals(s1)打印出来的内容却是flase。实际上equals方法比较的是两个对象的地址是否相等,那么这个时候就有疑问了,判断两个对象的地址是否相等明明有更简单的方法啊:

System.out.println(s1 == s2);

只需要这么写也可以判断两个对象的地址是否相等啊?那equals存在的意义在哪里呢?

实际上equals方法也是给我们用来重写的,例如我们重写让他来比较两个对象的内容是否是一样的,如果是一样的就返回true:

@Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        Student student = (Student) o;
        return age == student.age && Objects.equals(name, student.name);
    }

这样就可以让equals方法来判断两个对象的内容是否一致了。

其实上面的代码不需要我们手写,我们可以直接用IDEA生成:

在IDEA中输入eq,选择第二个,接下来一直点确定就好了。

3. clone()

说明:当某个对象调用这个方法时,这个方法会复制一个一模一样的新对象返回。

当我们想调用这个clone方法时,会发现这个clone方法无法调用,因为他被protected修饰了,只有obeject的子类,lang包才能使用。

protected:在子类,当前类的包下 中可以访问,在子类对象中不能访问。

那我们该怎么样才能使用克隆方法呢?

重写clone方法

@Override
    protected Object clone() throws CloneNotSupportedException {
        return super.clone();
        //通过super去调用父类Object中的clone方法
    }

要注意,不是所有类都可以克隆,我们还需要让当前类实现Cloneable接口才能让对象使用clone方法。Cloneable接口只是一个标记接口,他没有任何内容。

同时,我们还需要在主方法后面加上

public static void main(String[] args) throws CloneNotSupportedException {c

才能避免以报错形式出现的警告。

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值