4-3 jmu-java-m04-Person与equals覆盖

编写Person类 属性:String name, int age;
方法:
构造方法(name, age) 覆盖自Object中继承的boolean equals(Object o)方法。比较规则:name相等(忽略大小写)且age相等,则返回true。如果两者姓名均为为null,且age相等,则返回true。

main方法:
输入n行字符串(name age),并创建Person对象。如果name位置字符串null,则代表所创建的Person对象name属性为null(注意不是字符串"null")。

创建完对象后,在列表中查询有无与该对象相同的对象(equals为ture即为相同),如果没有则将该对象放入列表。

然后输出列表中的所有对象。

输入格式:
生成的对象数量n
n行字符串以空格分隔分别为name与age

输出格式:
格式化输出列表中的所有对象

输入样例:
8
Zheng 15
Zheng 15
Zheng 16
zhEng 16
zhEng 15
null 17
null 16
null 17

输出样例:
[Person [name=Zheng, age=15], Person [name=Zheng, age=16], Person [name=null, age=17], Person [name=null, age=16]]

作者: 郑如滨
单位: 集美大学
时间限制: 400 ms
内存限制: 64 MB

import java.util.*;

public class Main {
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		int n = sc.nextInt();
		List<Person> persons = new ArrayList<>();
		for(int k=0;k<n;k++)
		{
			String name = sc.next();
			String age0=sc.next();
			
			int age= Integer.parseInt(age0);	
			//空指针异常
//			if(name.equals("null"))
//			{
//				name=null;
//			}
			Person p = new Person(name,age);
			persons.add(p);
		
		}	
		for (int i = 0; i < persons.size()-1; i++) {
				for (int j = i + 1; j < persons.size(); j++) {
					if (persons.get(i).equals(persons.get(j))) {
						persons.remove(j);
						j--;
					}
				}
			}

		System.out.println(persons);
		
		
	}
}
class Person{
	private String name;
	private int age;
	
	public Person(String name,int age)
	{	
		if(name=="null")
		{
			this.name=null;
		}
		else
		{
			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;
	}

	public boolean equals(Object o)
	{
		if(o instanceof Person)
		{
			Person p = (Person)o;
			
			if (this.getName().equalsIgnoreCase(p.getName()) &&(this.getAge() == p.getAge()))
			
			{
		     return true;
		     }
			else if(this.getName()==null&&p.getName()==null&&this.getAge()==p.getAge())
			{
				return true;
			}
		
		}
			return false;
	}

	public String toString()
	 {
		 return "Person "+"[name="+this.name+", age="+this.age+"]";
	 }
}
### 回答1: 覆盖equals是面向对象编程中的两个重要概念。 覆盖指的是子类重写父类的方法,使得子类可以根据自己的需求来实现该方法。在覆盖时需要注意方法名、参数列表和返回值类型必须与父类方法一致,否则会编译错误。覆盖可以提高代码的复用性和可维护性。 equals是Object类中的一个方法,用于比较两个对象是否相等。默认情况下,equals方法比较的是两个对象的引用是否相等,即是否指向同一个内存地址。如果需要比较两个对象的内容是否相等,就需要在类中重写equals方法,并根据类的属性来比较对象的内容。在重写equals方法时,需要满足自反性、对称性、传递性和一致性等条件,否则可能会导致程序出错。 总之,覆盖equals都是面向对象编程中非常重要的概念,掌握它们可以提高代码的质量和效率。 ### 回答2: 覆盖equalsJava中面向对象编程的两个基础概念,它们的正确应用非常重要。 覆盖(Override)是指子类重写(覆盖)父类的方法。在Java中,子类可以重写其父类的方法,子类的方法名、参数类型和返回值类型必须与父类方法一致。通过覆盖,我们可以实现灵活的代码复用和更高效的代码运行。 在实际开发中,我们需要注意覆盖的一些规则:首先,被覆盖的方法必须有相同的方法名、参数列表和返回值类型;其次,覆盖的方法修饰符不能比被覆盖的方法更严格;最后,被覆盖的方法不能是final类型的。 equalsJava中的一个方法,它用于比较两个对象是否相等。在默认情况下,equals方法比较的是两个对象的引用地址,但是我们可以重写equals方法,来使其比较对象的内容是否相等。 当我们需要比较自定义的对象时,必须重写equals方法,因为默认的equals方法不能满足我们的需求。在自定义equals方法时,需要遵循几个规则:首先,比较对象时需要保证其一致性、反射性、对称性和传递性;其次,equals方法必须是自反的,并且不能与其他对象类型(如String类型)相等;最后,equals方法必须与hashCode方法一致。 总之,覆盖equals方法是Java中面向对象编程的非常基础的概念,我们需要在实际开发中灵活应用,以实现更高效、更灵活和更安全的代码编写。 ### 回答3: 覆盖是指子类可以覆盖父类中的某些方法,使得子类在调用这些方法时,执行的是自己的实现而不是父类的实现。而equals()方法是用来比较两个对象是否相等的方法,它是Object类中的一个方法,在子类中也可以重写。 在覆盖中,子类通过重写父类中的某些方法,可以添加或修改方法中的行为。在Java中,子类中必须要实现父类中的抽象方法,否则子类就必须声明为抽象类。同时,子类通过super关键字可以调用父类中被覆盖的方法,从而实现在子类中添加新的行为。 在equals()方法中,如果不重写,则会默认调用Object类中的equals()方法,这种比较方式只比较两个对象的引用是否相等,而不是对象的值是否相等。因此,在比较两个对象的值时,需要在子类中重写equals()方法,并根据实际需求来实现比较两个对象的值是否相等。 在重写equals()方法时,需要遵循以下几点原则: 1. 自反性:对于任何非 null 的对象 x,x.equals(x) 必须返回 true。 2. 对称性:对于任何非 null 的对象 x 和 y,如果 x.equals(y) 返回 true,则 y.equals(x) 必须返回 true。 3. 传递性:对于任何非 null 的对象 x、y 和 z,如果 x.equals(y) 返回 true,y.equals(z) 返回 true,则 x.equals(z) 必须返回 true。 4. 一致性:对于任何非 null 的对象 x 和 y,只要对象的状态没有发生改变,则 x.equals(y) 多次调用时必须返回相同的结果。 5. 非空性:对于任何非 null 的对象 x,x.equals(null) 必须返回 false。 综上所述,覆盖equals()方法都是非常重要的Java基础概念,对于Java程序员来说,熟练掌握这两个概念可以帮助我们更好地进行Java开发。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值