Java 重写(override)和重载(overloading)的区别

本文详细介绍了Java中的重写和重载概念及其区别。重写发生在子类中,保持外壳不变,核心重写,而重载则在同一类中,通过改变参数列表实现多态性。此外,文章还讨论了super关键字的使用和@override注解的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

重载和重写是类的多态性的重要体现,也是两个比较容易混淆的概念,这里做个学习笔记,mark下

一、重写和重载的区别

1、override

概念:存在于子类中,对父类允许访问的方法进行重写,返回值和形参都不能改变,即外壳不变,核心重写,是父类和子类间多态性的体现。

//定义动物类
class Animals{
	public void move() {
		System.out.println("Animals can move");
	}
}
//狗类继承动物类
class Dogs extends Animals{
	//继承move动作,多态
	public void move() {
		System.out.println("Dogs can run");
	}
	//狗类具备吠的动作
	public void bark() {
		System.out.println("Dogs bark all the time");
	}
}
//鸟类继承动物类
class Birds extends Animals{
	//继承move动作,多态
	public void move() {
		System.out.println("Birds can fly");
	}
}
public class overtest {
	/**
	 * @param args
	 */
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		//a,b,c都属于动物类,实际运行时,运行指定对象的方法,这就是多态
		Animals a = new Animals();
		Animals b = new Dogs();
		Animals c = new Birds();
		//为什么abc不报错,是因为在编译阶段,只是检查参数引用类型,animals类具备move方法,所以不报错
		Dogs d = new Dogs();
		a.move();
		b.move();
		c.move();
		d.bark();
	}
}
Animals can move
Dogs can run
Birds can fly
Dogs bark all the time

 可以看到上面 ,abc属于animals类,运行时运行的是指定对象的move方法,这就是重写实现的多态;如果在后面加上b.bark()就会报错,因为在编译阶段,b属于animals类的引用类型,animals类不具备bark方法,所以会报错。

override特点

  • 参数列表必须与重写方法相同
  • 父类成员方法只能被子类重写
  • 声明为final的方法不能被重写
  • 声明为static的方法不能被重写
  • 构造方法不能被重写
  • 可重写的方法必须是可继承的
  • 重写方法的访问权限不能比父类被重写的方法访问权限更低
  • 重写的方法能够抛出任何非强制异常,无论被重写的方法是否抛出异常。但是,重写的方法不能抛出新的强制性异常,或者比被重写方法声明的更广泛的强制性异常,反之则可以。

2、overloading

概念:存在于一个类里面,方法名字相同,参数不同,返回类型可以相同或不同,是类中多态性的体现,最常见的是构造器的重载。

//定义动物类
class Animal{
	//定义move方法
	protected void move() {
		System.out.println("animals can move");
	}
	//类内重载move方法
	public int move(int i) {
		return i;
	}
}
public class overtest {
	public static void main(String[] args) {
		Animal a = new Animal();
		a.move();
		System.out.println(a.move(10));
	}
}

 overloading特点

  • 重载的方法必须改变参数列表
  • 被重载的方法可以改变,返回类型,修饰符
  • 被重载的方法可以声明新的或更广的检查异常
  • 返回值类型无法作为重载函数的区分标准

二、super关键字的使用

在Java类中使用super来引用父类的成分,采用this来引用当前对象。

//定义动物类
class Animals{
	public Animals() {
		System.out.println("Animals 构造函数");
	}
	public void move() {
		System.out.println("Animals can move");
	}
}
//狗类继承动物类
class Dogs extends Animals{
	public Dogs() {
		//调用父类animals的构造方法
		super();
		//调用父类animals的move方法
		super.move();
		System.out.println("Dogs 构造函数");
	}
	//继承move动作,多态
	public void move() {
		System.out.println("Dogs can run");
	}
	//狗类具备吠的动作
	public void bark() {
		System.out.println("Dogs bark all the time");
	}
}
public class overtest {
	/**
	 * @param args
	 */
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		//a,b,c都属于动物类,实际运行时,运行指定对象的方法,这就是多态
		Animals a = new Animals();
		Animals b = new Dogs();
		//为什么abc不报错,是因为在编译阶段,只是检查参数引用类型,animals类具备move方法,所以不报错
		Dogs d = new Dogs();
		a.move();
		b.move();
		d.bark();
	}
}

super关键字特点

  • super():调用基类构造函数,且必须在子类构造方法第一行,父类的初始化要先完成,否则编译报错,如果super()在子类中不写,它也会被运行
  • super.变量名,super.方法:调用父类成员

三、@override的使用

1、用作注释,表明这个方法是重写父类的方法

2、如果注释了@override,下面的方法必须符合重写的规范,否则编译会报错,这样就防止了一种情况:该方法是要被重写的,但是写错了,编译器不报错,因为编译器以为这是一种子类新增的方法,如果注释了@override,编译器就知道这是重写方法,如果格式不对,编译器就会报错。形成良好的编码习惯哦~

### Java重写重载的概念及区别 #### 方法重写的定义 方法重写是指在子类中重新定义父类中的某个方法的行为,前提是该方法的名称、参数列表以及返回值类型完全一致。这种机制允许子类提供特定于自身的实现方式[^3]。需要注意的是,重写方法不能抛出新的强制性异常,也不能抛出比被重写方法更广泛的强制性异常[^4]。 #### 方法重载的定义 方法重载发生在同一个类内部,通过创建多个具有相同名称但参数列表不同的方法来实现。这些差异可能体现在参数的数量、类型或顺序上。方法重载并不关心返回值类型的改变,因为这不足以区分两个方法[^2]。 #### 主要区别 | **特性** | **方法重写 (Overriding)** | **方法重载 (Overloading)** | |---------------------|-------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------| | **发生位置** | 存在于父子类之间的继承关系中 | 发生在同一类的不同方法之间 | | **方法签名要求** | 名称、参数列表返回值类型必须完全匹配 | 只需保持方法名一致,而参数数量、类型或顺序可以不同 | | **访问修饰符规则** | 子类方法的访问权限不能低于父类 | 不受此限制 | | **异常处理** | 重写方法不能抛出新的强制性异常,也不得抛出比原方法范围更大的异常 | 对异常无特殊要求 | 以下是关于方法重写的一个简单示例: ```java class Parent { void display() { System.out.println("Parent Method"); } } class Child extends Parent { @Override void display() { // 这里实现了方法重写 System.out.println("Child Method"); } public static void main(String[] args) { Parent obj = new Child(); obj.display(); // 输出 "Child Method" } } ``` 对于方法重载的例子如下所示: ```java public class Example { int add(int a, int b) { // 定义第一个add方法 return a + b; } double add(double a, double b) { // 定义第二个add方法,参数类型不同 return a + b; } public static void main(String[] args) { Example example = new Example(); System.out.println(example.add(5, 7)); // 调用int版本的add方法 System.out.println(example.add(5.0, 7.0)); // 调用double版本的add方法 } } ``` 以上代码展示了如何利用方法重载满足不同类型数据的操作需求。 ### 总结 综上所述,方法重写主要涉及继承层次结构下的行为调整,强调一致性;而方法重载则是为了增强灵活性,在同一类内支持多种操作模式[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值