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)

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


相关文章
|
2月前
|
Java 编译器 数据安全/隐私保护
Java 重写(Override)与重载(Overload)详解
在 Java 中,重写(Override)和重载(Overload)是两个容易混淆但功能和实现方式明显不同的重要概念。重写是在子类中重新定义父类已有的方法,实现多态;重载是在同一类中定义多个同名但参数不同的方法,提供多种调用方式。重写要求方法签名相同且返回类型一致或为父类子类关系,而重载则关注方法参数的差异。理解两者的区别有助于更好地设计类和方法。
|
3月前
|
Java
【Java基础面试十八】、说一说重写与重载的区别
这篇文章阐述了Java中重写与重载的区别:重载是同一个类中方法名相同但参数列表不同的方法之间的关系,而重写是子类中方法与父类中相同方法名和参数列表的方法之间的关系,且子类的返回值应小于等于父类,访问修饰符应大于等于父类。
【Java基础面试十八】、说一说重写与重载的区别
|
3月前
|
Java
Java 新手入门:重载和重写傻傻分不清?一篇文章带你清晰理解!
Java 新手入门:重载和重写傻傻分不清?一篇文章带你清晰理解!
37 0
Java 新手入门:重载和重写傻傻分不清?一篇文章带你清晰理解!
|
3月前
|
Java
描述 Java 中的重载和重写
【8月更文挑战第22天】
19 0
|
4月前
|
Java
Java面向对象 ( 类与对象 | 构造方法 | 方法的重载 )
Java面向对象 ( 类与对象 | 构造方法 | 方法的重载 )
|
SQL 存储 Java
Java 应用与数据库的关系| 学习笔记
快速学习 Java 应用与数据库的关系。
204 0
Java 应用与数据库的关系| 学习笔记
|
SQL 存储 Java
Java 应用与数据库的关系| 学习笔记
快速学习 Java 应用与数据库的关系。
191 0
Java 应用与数据库的关系| 学习笔记
|
SQL 存储 关系型数据库
Java应用与数据库的关系|学习笔记
快速学习Java应用与数据库的关系
Java应用与数据库的关系|学习笔记
|
12天前
|
安全 Java 测试技术
Java并行流陷阱:为什么指定线程池可能是个坏主意
本文探讨了Java并行流的使用陷阱,尤其是指定线程池的问题。文章分析了并行流的设计思想,指出了指定线程池的弊端,并提供了使用CompletableFuture等替代方案。同时,介绍了Parallel Collector库在处理阻塞任务时的优势和特点。
|
8天前
|
安全 Java 开发者
深入解读JAVA多线程:wait()、notify()、notifyAll()的奥秘
在Java多线程编程中,`wait()`、`notify()`和`notifyAll()`方法是实现线程间通信和同步的关键机制。这些方法定义在`java.lang.Object`类中,每个Java对象都可以作为线程间通信的媒介。本文将详细解析这三个方法的使用方法和最佳实践,帮助开发者更高效地进行多线程编程。 示例代码展示了如何在同步方法中使用这些方法,确保线程安全和高效的通信。
28 9