7-5 jmu-Java-03面向对象基础-05-覆盖

文章提供了一个Java编程题目,要求创建一个PersonOverride类,覆盖Object的toString和equals方法。在main方法中,使用ArrayList存储对象,并根据用户输入判断是否添加新对象到列表,最后输出对象信息和数量。同时,文章提到了使用HashSet进行去重时需要重写hashCode方法。
摘要由CSDN通过智能技术生成

题目描述:

Java每个对象都继承自Object,都有equals、toString等方法。
现在需要定义PersonOverride类并覆盖其toStringequals方法。

1. 新建PersonOverride

a. 属性String nameint ageboolean gender,所有的变量必须为私有(private)。

b. 有参构造方法,参数为name, age, gender

c. 无参构造方法,使用this(name, age,gender)调用有参构造方法。参数值分别为"default",1,true

d.toString()方法返回格式为:name-age-gender

e. equals方法需比较name、age、gender,这三者内容都相同,才返回true.

2. main方法

2.1 输入n1,使用无参构造方法创建n1个对象,放入数组persons1。
2.2 输入n2,然后指定name age gender。每创建一个对象都使用equals方法比较该对象是否已经在数组中存在,如果不存在,才将该对象放入数组persons2。
2.3 输出persons1数组中的所有对象
2.4 输出persons2数组中的所有对象
2.5 输出persons2中实际包含的对象的数量
2.5 使用System.out.println(Arrays.toString(PersonOverride.class.getConstructors()));输出PersonOverride的所有构造方法。

**提示:**使用ArrayList代替数组大幅复简化代码,请尝试重构你的代码。

输入样例:

1
3
zhang 10 true
zhang 10 true
zhang 10 false

输出样例:

default-1-true
zhang-10-true
zhang-10-false
2
[public PersonOverride(), public PersonOverride(java.lang.String,int,boolean)]

答案:

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int m = sc.nextInt();
        ArrayList<PersonOverride> person1 = new ArrayList<>();
        ArrayList<PersonOverride> person2 = new ArrayList<>();
        for (int i = 0; i < n; i++) {
            person1.add(new PersonOverride());
        }
        for (int i = 0; i < m; i++) {
            String name = sc.next();
            int age = sc.nextInt();
            boolean gender = "true".equals(sc.next());
            PersonOverride temp = new PersonOverride(name,age,gender);
            

        //如果对象在集合不存在就添加
        if(Exists(person2,temp)){
            person2.add(temp);
        }
    }
    for (PersonOverride override : person1) {
        System.out.println(override.toString());
    }
    for (PersonOverride personOverride : person2) {
        System.out.println(personOverride.toString());
    }
    System.out.println(person2.size());
    System.out.println(Arrays.toString(PersonOverride.class.getConstructors()));

}

//验证对象在集合是否存在
private static boolean Exists(ArrayList<PersonOverride> person2, PersonOverride temp) {
    for (PersonOverride personOverride : person2) {
        if(personOverride.equals(temp)){
            return false;
        }
    }
    return true;
}

}
class PersonOverride{
    private String name;
    private int age;
    private boolean gender;

public PersonOverride() {
    this("default",1,true);
}

public PersonOverride(String name, int age, boolean gender) {
    this.name = name;
    this.age = age;
    this.gender = gender;
}

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;
}

public boolean isGender() {
    return gender;
}

public void setGender(boolean gender) {
    this.gender = gender;
}
//重写equals方法
@Override
public boolean equals(Object obj) {
    PersonOverride po = (PersonOverride)obj;
    if(!this.name.equals(po.getName())){
        return false;
    }
    if(!(this.age==po.getAge())){
        return false;
    }
    if(!(this.gender==po.isGender())){
        return false;
    }
    return true;
}
//重写toString方法
public String toString() {
    return name+"-"+age+"-"+gender;
}

}

解析:

这题主要看你会不会重写方法,我其实打算用hashSet集合直接去重,想了想还是算了,不过有小伙伴想用hashSet去重的话记得要重写Javabean里的HashCode方法,因为Object类里的hashCode是用地址值来计算hashCode的,不能达到按照我们想要的根据对象里的属性来去重

感兴趣的小伙伴可以点这个链接进行进一步的了解: (https://blog.csdn.net/weixin_44015626/article/details/107120469)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值