重载与重写有什么区别?

简介: 重载与重写有什么区别?

一、重载是什么?


在 Java 中,如果多个方法的名字相同,参数列表不同,则称该几种方法就被重载了 。

public static int add(int x, int y) { 
   return x + y;
}
public static double add(double x, double y) {
   return x + y; 
}
public static double add(double x, double y, double z) {
   return x + y + z; 
}

注意:

1. 方法名必须相同

2. 参数列表必须不同 ( 参数的个数不同、参数的类型不同、类型的次序必须不同 )

3. 与返回值类型是否相同无关

4. 编译器在编译代码时,会根据实参类型来确定调用哪个方法


二、重写是什么?


重写 (override) :也称为覆盖。重写是子类对父类 非静态 、 非private修饰 , 非final修饰 , 非构造

方法 等的实现过程进行重新编写, 返回值和形参都不能改变 。 重写的好处在于子类可以根据需要,

定义特定于自己的行为。 也就是说子类能够根据需要实现父类的方法。

1.子类在重写父类的方法时,返回值类型、 方法名 ( 参数列表 ) 要完全一致

2.被重写的方法返回值类型可以不同,但是必须是具有父子关系

3.访问权限不能比父类中被重写的方法的访问权限更低。例如:如果父类方法被 public 修饰,则子类中重写该方法就不能声明为 protected

4.父类被 static 、 private 修饰的方法、构造方法都不能被重写。

5.重写的方法 , 可以使用 @Override 注解来显式指定 . 有了这个注解能帮我们进行一些合法性校验 . 例如不小心将方法名字拼写错了 ( 比如写成 aet), 那么此时编译器就会发现父类中没有 aet 方法 , 就会编译报错 , 提示无法构成重写.


三、避免在构造方法中调用重写的方法


创建两个类, B 是父类, D 是子类. D 中重写 func 方法. 并且在 B 的构造方法中调用 func

class B {
  public B() {
    // do nothing 
    func(); 
  }
  public void func() {
    System.out.println("B.func()");
  }
}
class D extends B {
  private int num = 1;
  @Override
  public void func() { 
    System.out.println("D.func() " + num); 
  }
}
public class Test {
  public static void main(String[] args) { 
    D d = new D(); 
  } 
}
// 执行结果 
D.func() 0


构造 D 对象的同时, 会调用 B 的构造方法。


B 的构造方法中调用了 func 方法, 此时会触发动态绑定, 会调用到 D 中的 func。


此时 D 对象自身还没有构造 , 此时 num 处在未初始化的状态 , 值为 0.。 如果具备多态性, num 的值应该是 1。

所以在构造函数内,尽量避免使用实例方法,除了 final 和 private 方法。

尽量不要在构造器中调用方法(如果这个方法被子类重写, 就会触发动态绑定, 但是此时子类对象还没构造完成), 可能会出现一些隐藏的但是又极难发现的问题.


四、重载与重写的区别?


区别点 重写(override) 重载
参数列表 不能修改 必须修改
返回类型 不能修改(除非可以构成父子类关系) 可以修改(不做要求)
访问限定符 子类的访问权限大于等于父类的访问权限 可以修改


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


相关文章
|
Linux 开发工具 Android开发
python之实现apk
python之实现apk
|
机器学习/深度学习 数据采集 算法
Python实现PCA降维和KNN人脸识别模型(PCA和KNeighborsClassifier算法)项目实战
Python实现PCA降维和KNN人脸识别模型(PCA和KNeighborsClassifier算法)项目实战
|
机器学习/深度学习 人工智能 自然语言处理
深度学习中的注意力机制:技术洞察与应用前景
在人工智能的浪潮下,深度学习技术以其强大的数据处理和模式识别能力引领着技术发展的前沿。特别是注意力机制的引入,它模仿人类视觉注意力的选择性聚焦,极大地提高了模型处理序列数据的效率和准确度。本文将深入解析注意力机制的原理,探讨其在自然语言处理、计算机视觉等领域的应用,并预测未来的发展趋势。通过严谨的逻辑推理和丰富的数据支撑,我们旨在展现注意力机制如何成为深度学习领域的重要创新点。
|
人工智能 物联网 Linux
Fooocus:一个简单且功能强大的Stable Diffusion webUI
Stable Diffusion是一个强大的图像生成AI模型,但它通常需要大量调整和提示工程。Fooocus的目标是改变这种状况。
1080 1
|
监控 算法 搜索推荐
我在阿里做测开
如何转型测试开发
|
Web App开发 安全 Android开发
如何上架自己的应用到各大应用商店?
上架各大安卓应用商店(腾讯应用宝、阿里应用商店、百度手机助手、华为应用市场、小米应用商店)需要准备哪些材料?
1014 0
|
存储 NoSQL Cloud Native
【福利】阿里云数据库电子书合集开放下载!从开源数据库到阿里巴巴实战,一键全包!
这次社区为大家打包带来阿里云数据库团队出品的8本电子书,这些电子书不仅涵盖了MySQL、MongoDB等流行数据库的技术详解及阿里云实战经验,还囊括了前沿数据库技术的深入分析和探讨,绝对让你大呼过瘾!最最关键的是,这些电子书全部都可以免费下载!
12231 0
【福利】阿里云数据库电子书合集开放下载!从开源数据库到阿里巴巴实战,一键全包!
|
Kubernetes Cloud Native Linux
使用kind快速搭建本地k8s集群
Kind是什么? k8s集群的组成比较复杂,如果纯手工部署的话易出错且时间成本高。而本文介绍的KindI具,能够快速的建 立起可用的k8s集群,降低初学者的学习门槛。 Kind是Kubernetes In Docker的缩写,顾名思义,看起来是把k8s放到docker的意思。没错,kind创建k8s集 群的基本原理就是:提前准备好k8s节点的镜像,通过docker启动容器,来模拟k8s的节点,从而组成完整的 k8s集群。需要注意, kind创建的集群仅可用于开发、学习、测试等,不能用于生产环境。
|
SQL 弹性计算 运维
基于HBR的云上统一备份
混合云备份(简称HBR)是一种简单易用且高性价比的在线备份服务,可以为阿里云ECS,NAS,OSS以及自建机房内的各类数据提供安全,高效的保护。
887 0
基于HBR的云上统一备份