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)

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


相关文章
|
10天前
|
存储 Java 程序员
Java的基础概念一
### Java编程基础简介 #### 一、注释 注释用于解释代码,不会参与编译和运行。Java支持三种注释: - **单行注释**:以 `//` 开头。 - **多行注释**:以 `/* ... */` 包围。 - **文档注释**:通常用于生成开发文档。 #### 二、关键字 关键字是被Java赋予特定含义的英文单词,全部小写,且在代码编辑器中有特殊颜色标记。常用的如 `class` 表示定义一个类。
Java的基础概念一
|
5月前
|
Java 程序员
Java中的继承和多态:理解面向对象编程的核心概念
【8月更文挑战第22天】在Java的世界中,继承和多态不仅仅是编程技巧,它们是构建可维护、可扩展软件架构的基石。通过本文,我们将深入探讨这两个概念,并揭示它们如何共同作用于面向对象编程(OOP)的实践之中。你将了解继承如何简化代码重用,以及多态如何为程序提供灵活性和扩展性。让我们启程,探索Java语言中这些强大特性的秘密。
|
2月前
|
算法 Java 数据库连接
Java连接池技术,从基础概念出发,解析了连接池的工作原理及其重要性
本文详细介绍了Java连接池技术,从基础概念出发,解析了连接池的工作原理及其重要性。连接池通过复用数据库连接,显著提升了应用的性能和稳定性。文章还展示了使用HikariCP连接池的示例代码,帮助读者更好地理解和应用这一技术。
63 1
|
4月前
|
Java 编译器 数据安全/隐私保护
Java 重写(Override)与重载(Overload)详解
在 Java 中,重写(Override)和重载(Overload)是两个容易混淆但功能和实现方式明显不同的重要概念。重写是在子类中重新定义父类已有的方法,实现多态;重载是在同一类中定义多个同名但参数不同的方法,提供多种调用方式。重写要求方法签名相同且返回类型一致或为父类子类关系,而重载则关注方法参数的差异。理解两者的区别有助于更好地设计类和方法。
360 1
|
4月前
|
监控 算法 Java
深入理解Java中的垃圾回收机制在Java编程中,垃圾回收(Garbage Collection, GC)是一个核心概念,它自动管理内存,帮助开发者避免内存泄漏和溢出问题。本文将探讨Java中的垃圾回收机制,包括其基本原理、不同类型的垃圾收集器以及如何调优垃圾回收性能。通过深入浅出的方式,让读者对Java的垃圾回收有一个全面的认识。
本文详细介绍了Java中的垃圾回收机制,从基本原理到不同类型垃圾收集器的工作原理,再到实际调优策略。通过通俗易懂的语言和条理清晰的解释,帮助读者更好地理解和应用Java的垃圾回收技术,从而编写出更高效、稳定的Java应用程序。
|
5月前
|
Java Docker 微服务
微服务架构的概念、特点以及如何在Java Web开发中实现微服务。
微服务架构的概念、特点以及如何在Java Web开发中实现微服务。
113 1
|
5月前
|
存储 安全 Java
如何理解java的泛型这个概念
理解java的泛型这个概念
|
5月前
|
Java
描述 Java 中的重载和重写
【8月更文挑战第22天】
23 0
|
8天前
|
Java
Java—多线程实现生产消费者
本文介绍了多线程实现生产消费者模式的三个版本。Version1包含四个类:`Producer`(生产者)、`Consumer`(消费者)、`Resource`(公共资源)和`TestMain`(测试类)。通过`synchronized`和`wait/notify`机制控制线程同步,但存在多个生产者或消费者时可能出现多次生产和消费的问题。 Version2将`if`改为`while`,解决了多次生产和消费的问题,但仍可能因`notify()`随机唤醒线程而导致死锁。因此,引入了`notifyAll()`来唤醒所有等待线程,但这会带来性能问题。
Java—多线程实现生产消费者
|
10天前
|
安全 Java Kotlin
Java多线程——synchronized、volatile 保障可见性
Java多线程中,`synchronized` 和 `volatile` 关键字用于保障可见性。`synchronized` 保证原子性、可见性和有序性,通过锁机制确保线程安全;`volatile` 仅保证可见性和有序性,不保证原子性。代码示例展示了如何使用 `synchronized` 和 `volatile` 解决主线程无法感知子线程修改共享变量的问题。总结:`volatile` 确保不同线程对共享变量操作的可见性,使一个线程修改后,其他线程能立即看到最新值。