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

7-1 jmu-Java-03面向对象基础-05-覆盖 (3 分)
Java每个对象都继承自Object,都有equals、toString等方法。
现在需要定义PersonOverride类并覆盖其toString与equals方法。

  1. 新建PersonOverride类
    a. 属性:String name、int age、boolean 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.

  1. 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的所有构造函数。
    输入样例:
    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)]

关于这个题目的思路,我们按部就班,建立PersonOverride类,无参构造函数用this调用有参构造函数,toString和equals方法直接用source里面的toString和Hash and equals方法自动生成。
主方法中,比较难的一点就是2.2,我们可以定义一个int变量count,count就是person2数组中的实际对象数量,在for大循环下new一个p对象,然后int一个j=0,用while循环判断p在person2中是否存在,如果不存在就放入,存在就跳出循环。
2.4 2.5要注意输出的时候用count进行for循环,2.5中输出的也是count的值
2.6直接复制粘贴就OK
代码如下:
import java.util.*;
public class Main {

	public static void main(String[] args) {
		Scanner in = new Scanner(System.in);
		int n1 = in.nextInt();
		int i;
		PersonOverride person1[] = new PersonOverride[n1];
		for (i = 0; i < n1; i++) {
			person1[i] = new PersonOverride();
		}
		int n2 = in.nextInt();
		PersonOverride person2[] = new PersonOverride[n2];
		int count=0;
		PersonOverride p = null;
		for (i = 0; i < n2; i++) {
			p = new PersonOverride(in.next(), in.nextInt(), in.nextBoolean());
			int j = 0;
			while (j < count) {
				if (p.equals(person2[j]))
					break;
				j++;
			}
			if (j >= count) {
				person2[count] = p;
				count++;
			}
		}
		in.close();
		for(i=0;i<n1;i++)
		{
			System.out.println(person1[i].toString());
		}
		for (i = 0; i < count; i++) {
			System.out.println(person2[i].toString());
		}
		System.out.println(count);
		System.out.println(Arrays.toString(PersonOverride.class.getConstructors()));
	}
}

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

	@Override
	public String toString() {
		return name + "-" + age + "-"+ gender;
	}

	@Override
	public int hashCode() {
		final int prime = 31;
		int result = 1;
		result = prime * result + age;
		result = prime * result + (gender ? 1231 : 1237);
		result = prime * result + ((name == null) ? 0 : name.hashCode());
		return result;
	}

	@Override
	public boolean equals(Object obj) {
		if (this == obj)
			return true;
		if (obj == null)
			return false;
		if (getClass() != obj.getClass())
			return false;
		PersonOverride other = (PersonOverride) obj;
		if (age != other.age)
			return false;
		if (gender != other.gender)
			return false;
		if (name == null) {
			if (other.name != null)
				return false;
		} else if (!name.equals(other.name))
			return false;
		return true;
	}

}
### 回答1: 覆盖,又称重写或重载,是面向对象编程中的一种重要概念。它指子类对父类中已有的方法进行重新定义,使得子类中的方法能够覆盖父类中的方法,从而实现多态性。 要使用覆盖,需要遵循如下规则: - 方法名、参数列表、返回类型必须完全一致 - 方法的访问权限不能比父类中的方法更严格 - 方法的异常类型不能比父类中的方法更广 覆盖有助于提高代码的复用性和可维护性。 ### 回答2: 面向对象编程中最重要的概念之一是覆盖覆盖发生在两个有继承关系的类之间,其中,子类覆盖了父类中的方法。简单来说,子类中的方法与父类中的方法具有相同的名称和参数列表。 覆盖主要包括三个方面的内容:方法名称、参数列表以及返回类型。在覆盖的过程中,子类可以改变任何一个或多个方面的内容,但只要方法的名称和参数列表相同,就可以进行覆盖覆盖的主要作用是实现多态性。在面向对象编程中,多态指的是同一个方法或同一个类在不同的情况下表现出不同的行为。例如,一个父类有一个run方法,这个方法被多个子类继承并覆盖,这些子类的run方法可以根据不同的需要执行不同的代码,这就是多态性的体现。 需要注意的是,在进行覆盖时,子类的方法访问控制符不能低于父类的方法访问控制符。例如,如果父类的方法是public,那么子类的方法也必须是public,不能是private或protected。 覆盖还有一些注意事项。首先,覆盖必须使用@Override注解,这样可以确保方法签名的正确性。其次,在覆盖过程中,可以使用super关键字调用父类的方法实现,这个功能非常有用。 最后,需要注意的是,覆盖只适用于非静态方法。静态方法不受覆盖影响,因为静态方法是根据类调用,而不是根据对象调用。 总之,覆盖面向对象编程中非常重要的一个概念。它可以实现多态性,并且可以根据不同的需求调用不同的方法实现。同时,需要注意覆盖的访问控制符、使用@Override注解以及调用父类方法的方式。 ### 回答3: Java中的覆盖指的是在子类中使用相同的方法名称、参数列表和返回类型重新定义父类中已经存在的方法,从而达到替代父类中方法的效果。 父类中的方法被子类覆盖后,当调用子类对象的该方法时,实际上是优先调用子类中的方法,而不是父类中的方法。这就是覆盖的作用。 覆盖也可以称作重写,其实质是子类继承了父类的方法,并重新实现了这些方法,从而强化了子类对这些方法的掌控能力,实现了更加灵活的程序设计。 在将一个方法覆盖时,需要注意以下几点: 1.方法名称、参数列表、返回类型必须与被覆盖的方法相同,否则无法实现覆盖。 2.子类中覆盖的方法不能比父类中的方法访问级别更严格,例如:如果父类中的方法为public,那么子类中被覆盖的方法也必须为public,不能为private或者protected。 3.被覆盖的方法不能为final或者static,因为final的方法不能被重新定义,而static的方法不属于任何对象,不能被继承。 在实际程序设计中,也需要注意覆盖的使用方式。例如,当父类中的方法被覆盖时,子类中的方法可以根据需要选择是完全重写父类中的方法,还是在父类方法的基础上增加新功能。同时,在使用super关键字调用父类中被覆盖的方法时,需要注意调用的方式和位置,避免出现死循环或者错误的调用结果。 总的来说,覆盖Java中一个重要的特性,它使得程序设计更加灵活,同时也需要程序员在设计时根据实际需要合理使用。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值