Java——重写(Override)与重载(Overload)(概念理解+应用举例)

简介: Java——重写(Override)与重载(Overload)(概念理解+应用举例)

1.重写Override


重写是子类对父类当中允许访问的方法的实现过程进行重新编写,返回值和形参都不能改变。即外壳不变,核心重写!

重写的好处在于子类可以根据需要,定义自己特定的行为,也就是说子类能够根据需要实现父类的方法。

重写方法不能抛出新的检查异常或者比被重写方法声明更加宽泛的异常。例如:父类的一个方法申明了一个检查异常 IOException,但是在重写这个方法的时候不能抛出 Exception 异常,因为 Exception IOException 的父类,只能抛出 IOException 的子类异常。

方法的重写规则如下:

参数列表必须完全与被重写方法的相同。如果不能继承一个方法,则不能重写这个方法。

返回类型与被重写方法的返回类型相同。

访问权限不能比父类中被重写的方法的访问权限更低。例如:如果父类的一个方法被声明为 public,那么在子类中重写该方法就不能声明为 protected

父类的成员方法只能被它的子类重写。

声明为 final 的方法不能被重写。构造方法不能被重写。

声明为 static 的方法不能被重写,但是能够被再次声明。

子类和父类在同一个包中,那么子类可以重写父类所有方法,除了声明为 private final 的方法。

子类和父类不在同一个包中,那么子类只能够重写父类的声明为 public protected 的非 final 方法。

重写的方法能够抛出任何非强制异常,无论被重写的方法是否抛出异常。但是,重写的方法不能抛出新的强制性异常,或者比被重写方法声明的更广泛的强制性异常,反之则可以。

下面,我们来看两个例子:👇👇👇

Example 1

 

class AnimalPark {
  public void move() {
    System.out.println("动物可以移动!");
  }
}
class Dogs extends AnimalPark {
  public void move() {
    System.out.println("狗可以跑和跳!");
  }
}
public class Override {
  public static void main(String[] args) {
    AnimalPark a=new AnimalPark();
    AnimalPark b=new Dogs();
    a.move();
    b.move();
  }
}

在上面的例子中可以看到,尽管 b 属于 AnimalPark 类型,但是它运行的是 Dogs 类的 move方法。

这是由于在编译阶段,只是检查参数的引用类型。

然而在运行时,Java 虚拟机(JVM)指定对象的类型并且运行该对象的方法。

在上面的例子中,之所以能编译成功,是因为 AnimalPark 类中存在 move 方法,然而运行时,运行的是特定对象的方法。

程序运行结果如下:👇👇👇


Example 2 


class AnimalPark {
  public void move() {
    System.out.println("动物可以移动!");
  }
}
class Dogs extends AnimalPark {
  public void move() {
    System.out.println("狗可以跑和跳!");
  }
  public void bark() {
    System.out.println("狗可以吠叫");
  }
}
public class Override {
  public static void main(String[] args) {
    AnimalPark a=new AnimalPark();
    AnimalPark b=new Dogs();
    a.move();
    b.move();
    //b.bark();此行代码会报错!!!
  }
}

该程序将抛出一个编译错误,因为 b 的引用类型 AnimalPark 中没有 bark 方法。 

 

2.重载(Overload 


重载(overloading) 是在一个类中,对一个类进行重新编写,方法名字相同,而参数不同,返回类型可以相同也可以不同。

每个重载的方法(或者构造函数)都必须有一个独一无二的参数类型列表。

最常用的地方就是构造器的重载。

方法的重载规则如下:

被重载的方法必须改变参数列表(参数个数或类型不一样)

被重载的方法可以改变返回类型以及访问修饰符。

被重载的方法可以声明新的或更广泛的检查异常。

方法能够在同一个类中或者在一个子类中被重载。

无法以返回值类型作为重载函数的区分标准。

下面,我们来看一个重载的例子:👇👇👇


Example 1


class Overloading {
  public int test() {
    System.out.println("test1");
        return 1;
    }
    public void test(int a) {
        System.out.println("test2");
    }   
    //以下两个方法中参数类型的顺序不同
    public String test(int a,String s) {
        System.out.println("test3");
        return "test方法被重载第二次";
    }   
    public String test(String s,int a) {
        System.out.println("test4");
        return "test方法被重载第三次";
    }
}
public class Overload {
  public static void main(String[] args) {
    Overloading a=new Overloading();
        System.out.println(a.test());
        a.test(1);
        System.out.println(a.test(1,"test3"));
        System.out.println(a.test("test4",1));
  }
}

在这个例子中,可以看到,我们对类 Overloading 中的 test 方法进行了重载,其中,我们分别修改了参数列表和返回类型,当然了,你也可以修改访问修饰符、或者声明其他异常等。程序的运行结果如下:👇👇👇

3.重写和重载的区别 


 


4.总结 


方法重写是在子类中存在方法与父类的方法的名字相同,而且参数的个数与类型一样,返回值也一样的方法,则称为方法的重写(Overriding)

方法重载是一个类中定义了多个方法名相同,而他们的参数的数量不同或数量相同而类型和次序不同,则称为方法的重载(Overloading)

方法重写是子类与父类的一种多态性表现,方法重载是一个类的多态性表现。


相关文章
|
29天前
|
Java 编译器
在Java中,关于final、static关键字与方法的重写和继承【易错点】
在Java中,关于final、static关键字与方法的重写和继承【易错点】
20 5
|
2月前
|
Java 编译器 数据安全/隐私保护
Java 重写(Override)与重载(Overload)详解
在 Java 中,重写(Override)和重载(Overload)是两个容易混淆但功能和实现方式明显不同的重要概念。重写是在子类中重新定义父类已有的方法,实现多态;重载是在同一类中定义多个同名但参数不同的方法,提供多种调用方式。重写要求方法签名相同且返回类型一致或为父类子类关系,而重载则关注方法参数的差异。理解两者的区别有助于更好地设计类和方法。
|
3月前
|
Java
【Java基础面试十八】、说一说重写与重载的区别
这篇文章阐述了Java中重写与重载的区别:重载是同一个类中方法名相同但参数列表不同的方法之间的关系,而重写是子类中方法与父类中相同方法名和参数列表的方法之间的关系,且子类的返回值应小于等于父类,访问修饰符应大于等于父类。
【Java基础面试十八】、说一说重写与重载的区别
|
3月前
|
Java
【Java基础面试二十二】、为什么要重写hashCode()和equals()?
这篇文章解释了为什么需要重写`hashCode()`和`equals()`方法:因为Object类的`equals()`默认使用`==`比较,这在业务中通常是不够的,我们需要根据对象内容来比较相等性;同时,为了保持`hashCode()`与`equals()`的联动关系,一旦重写了`equals()`,通常也需要重写`hashCode()`。
【Java基础面试二十二】、为什么要重写hashCode()和equals()?
|
3月前
|
Java
【Java基础面试十九】、构造方法能不能重写?
这篇文章指出Java中的构造方法不能被重写,因为构造方法必须与类名相同,而重写要求子类方法与父类方法同名,允许构造方法重写将违背这一规则。
【Java基础面试十九】、构造方法能不能重写?
|
3月前
|
Java
描述 Java 中的重载和重写
【8月更文挑战第22天】
18 0
|
3月前
|
存储 Java 索引
|
11天前
|
监控 安全 Java
在 Java 中使用线程池监控以及动态调整线程池时需要注意什么?
【10月更文挑战第22天】在进行线程池的监控和动态调整时,要综合考虑多方面的因素,谨慎操作,以确保线程池能够高效、稳定地运行,满足业务的需求。
90 38
|
9天前
|
安全 Java
java 中 i++ 到底是否线程安全?
本文通过实例探讨了 `i++` 在多线程环境下的线程安全性问题。首先,使用 100 个线程分别执行 10000 次 `i++` 操作,发现最终结果小于预期的 1000000,证明 `i++` 是线程不安全的。接着,介绍了两种解决方法:使用 `synchronized` 关键字加锁和使用 `AtomicInteger` 类。其中,`AtomicInteger` 通过 `CAS` 操作实现了高效的线程安全。最后,通过分析字节码和源码,解释了 `i++` 为何线程不安全以及 `AtomicInteger` 如何保证线程安全。
java 中 i++ 到底是否线程安全?
|
3天前
|
存储 设计模式 分布式计算
Java中的多线程编程:并发与并行的深度解析####
在当今软件开发领域,多线程编程已成为提升应用性能、响应速度及资源利用率的关键手段之一。本文将深入探讨Java平台上的多线程机制,从基础概念到高级应用,全面解析并发与并行编程的核心理念、实现方式及其在实际项目中的应用策略。不同于常规摘要的简洁概述,本文旨在通过详尽的技术剖析,为读者构建一个系统化的多线程知识框架,辅以生动实例,让抽象概念具体化,复杂问题简单化。 ####