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

题目描述:

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)

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. Vector的组合操作是线程安全的。Vector是通过在每个方法上添加synchronized关键字来实现线程安全的。这意味着同一时间只能有一个线程访问Vector的方法,从而避免了多线程并发访问导致的数据不一致性问题。 2. 要实现一个复合型的操作,可以使用事务来保证一组操作的原子性。在Java中,可以使用数据库的事务来实现复合型操作,或者使用编程语言提供的事务管理器。 3. ArrayList进行序列化和反序列化可以使用Java的序列化机制。通过实现Serializable接口,在需要序列化和反序列化的ArrayList上添加关键字transient,并提供自定义的readObject和writeObject方法来控制序列化和反序列化的过程。 4. 如果已有一个ArrayList想得到一个线程安全的List,可以使用Collections类中的synchronizedList方法。该方法返回一个线程安全的List,它使用synchronized关键字来保证方法的同步访问。 5. synchronizedList和Vector都实现了List接口并提供了线程安全的操作。它们的主要区别在于线程安全的实现方式不同。synchronizedList使用了内部对象锁来保证方法的同步访问,而Vector在每个方法上使用了synchronized关键字来实现同步访问。 6. 在遍历时同时删除元素,不能直接使用foreach循环或普通for循环来删除元素,因为会引发ConcurrentModificationException异常。可以使用迭代器的remove方法来删除元素,或者使用ListIterator的remove方法。这是因为在遍历过程中使用迭代器或ListIterator的remove方法,会更新迭代器的状态并保持一致性,符合fail-fast机制。 7. HashMap的数据结构是哈希表(hash table)。底层存储是一个数组,每个数组元素对应一个链表或红黑树。通过计算键的哈希值,将键值对映射到数组的对应位置,解决哈希冲突采用链表或红黑树。 8. 使用数组+列表的主要目的是为了兼顾数组和列表的优点。数组在访问元素时效率高,而列表在动态添加和删除元素时效率高。通过使用数组+列表的结构,可以充分利用两者的优点,同时满足不同的操作需求。 9. hashCode方法用于计算对象的哈希码,equals方法用于判断两个对象是否相等。hashCode方法和equals方法是配套使用的,当两个对象的hashCode相等并且equals方法返回true时,它们被认为是相等的对象。 10. equals方法可以重写。重写equals方法的目的是根据业务需求重新定义两个对象是否相等的逻辑。一般需要重写equals方法时,也需要同时重写hashCode方法以保持一致性。 11. IDEA生成equals方法有多种方法,可以通过快捷键Alt+Insert,选择"equals() and hashCode()"来自动生成equals方法。也可以通过右键菜单选择"Generate",然后选择"equals() and hashCode()"来生成equals方法。 12. toString方法的实现有多种方法。可以手动实现toString方法,在方法中返回对象的字符串表示。也可以使用第三方库,如Apache Commons Lang中的ToStringBuilder或Guava中的ToStringHelper来简化toString方法的实现。 13. Java中的字符串拼接有多种方式,包括使用"+"操作符、使用StringBuilder或StringBuffer的append方法、使用字符串模板(如String.format)等。 14. "+"操作符是基于StringBuilder或StringBuffer实现的。在编译时,Java编译器会对字符串拼接表达式进行优化,将其转换为使用StringBuilder或StringBuffer的append方法来实现字符串拼接。 15. Java中的字符串是不可变的。final关键字修饰的类确保该类不可被继承,而不是字符串本身的可变性。不可变的字符串意味着一旦创建就不能修改其值,任何修改字符串的操作都会创建一个新的字符串对象。 16. Java中没有固定的长度限制。根据具体的实现和系统资源限制,字符串的长度可能有一定的限制,但一般情况下可以存储非常大的字符串。 17. 哈希算法常见的有MD5、SHA-1、SHA-256等。哈希冲突可以通过增加哈希表的长度、使用更好的哈希函数、使用链表或红黑树等方式来解决。其中,常见的解决哈希冲突的方法有开放寻址法和链地址法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值