问题出现:

  即使对于一个经验丰富的开发人员来说,方法重载和方法覆盖的区别都能让他犹豫一下, 对于新手来说,经常容易弄混淆。

  有没有比较深入浅出的理解方式,能让人过目不忘,用起来还能有条件反射般的速度呢?

其他人是怎么做的:

  写类似比较的博客非常之多,无非也就是分开介绍,然后比较区别。

  好像也有效果,前提是要理解,完了还要不时拿来复习,保持记忆不被遗忘。

可以这样理解:

  override 更准确的翻译应该是推翻,重写。

  overload 更准确的翻译应该是过载。

  如果你不是新手,看到这个解释的时候应该有点茅塞顿开的感觉,

  因为直译之后的意思就是这两个方式的功能概括。

  所以:

  override 个人喜欢叫做方法重写;

  overload 个人喜欢叫做方法过载。

分析:

  为什么叫方法重写:

    1.父类中的方法满足不了需要,子类可以推翻父类中的方法。
    2.同样的方法名称,参数列表,返回类型,抛出的异常(或者是父类抛出的异常的子类),子类重写一个。
    3.所以方法重写要求很严格,除了方法体内部的实现和访问权限,其他的都要和父类中需要被重写的方法保持一致。
    有一点要特别注意,方法重写之后访问权限可以不同:

      可以扩大访问权限,但是不能降低访问权限。

      可以看作是对子类的兼容性和拓展性要求的折衷妥协吧。

    注意:被重写的方法访问权限不能为 private,因为 private 修饰的方法子类没有访问权限,更不要提重写。

  为什么叫方法过载:

    1.过载指的是应对不同的参数列表而产生的方法过载。
    2.所以方法过载要求方法名称必须相同,参数列表必须不同;
    3.访问权限,返回类型,抛出的异常之类的可以相同也可以不同。

      使用方法过载的目的,根据调用时的实参表与形参表,来选择对应的方法体的。

    注意:如果某一方法在父类中是访问权限是 private,那么就不能在子类对其进行重载;
    如果定义的话,也只是定义了一个新方法,而不会达到重载的效果。

练习一下:

class A {
protected int method1(int a, int b) { return 0; }
} public class B extends A{
public int method1(int a, int b) { return 0; }
// private int method1(int a, int b) { return 0; }
// private long method1(int a, int b) { return 0; }
public short method1(int a, long b) { return 0; }
private int method1(int a, long b) { return 0; }
} (参考答案预警!你不打算在心里演算一下么?)

参考答案:

class A {
protected int method1(int a, int b) { return 0; }
} public class B extends A{
public int method1(int a, int b) { return 0; } // 正确,重写父类方法,可以扩大访问权限
// private int method1(int a, int b) { return 0; } // 错误,重写父类方法,不能降低了访问权限
// private long method1(int a, int b) { return 0; } // 错误,重写父类方法,不能改变返回值类型
public short method1(int a, long b) { return 0; } // 正确,method1 方法参数过载,可以有不同的访问权限和返回值类型
private int method1(int a, long b) { return 0; }/ /正确,method1 方法参数过载,可以有不同的访问权限和返回值类型
}

小结:

override 方法重写,也叫方法覆盖;
  要求与被重写的方法:
    名称相同,
    参数列表相同,
    返回类型相同,
    抛出的异常相同(或者是父类抛出的异常的子类)。
  被重写的方法访问权限不能为 private

overload 方法过载;
  要求过载的方法:
    方法名称必须相同;
    参数列表必须不同;
    访问权限,返回类型,抛出的异常可以相同也可以不同。

传送门:https://blog.51cto.com/13508140/2339876
本文系笔者原创
转载请注明出处
—————————————

Java 中 override 和 overload 区别的更多相关文章

  1. Java 中override、overload、overwrite区别,以及与多态的关系【转】

    因为早期的翻译导致了override和overwrite的解释及理解混乱,需要重新梳理这几个词及相关内容. 转自:http://blog.csdn.net/lzhang007/article/deta ...

  2. 测者的测试技术手册:分清Java的Override和Overload

    Java的Override和OverloadOverride重写:子类对父类的允许访问的方法实现过程重新编写,但是 不可改变返回值和入参.重弄写的规则: 参数列表必须完全与被重写方法的相同: 返回类型 ...

  3. java中ArrayList 、LinkList区别

    转自:http://blog.csdn.net/wuchuanpingstone/article/details/6678653 个人建议:以下这篇文章,是从例子说明的方式,解释ArrayList.L ...

  4. java 中 ==和equals 的区别

      Java中equals和==的区别 java中的数据类型,可分为两类: 1.基本数据类型,也称原始数据类型.byte,short,char,int,long,float,double,boolea ...

  5. java中equals和==的区别 (转)

    java中equals和==的区别  值类型是存储在内存中的堆栈(以后简称栈),而引用类型的变量在栈中仅仅是存储引用类型变量的地址,而其本身则存储在堆中. ==操作比较的是两个变量的值是否相等,对于引 ...

  6. 【转】Java中equals和==的区别

    [转]Java中equals和==的区别 java中的数据类型,可分为两类: 1.基本数据类型,也称原始数据类型.byte,short,char,int,long,float,double,boole ...

  7. java中a++与++a区别

    java中a++与++a区别 a++与++a的区别,如果单独使用没有任何区别,如果在运算中就有区别了,a++是先运算在赋值,而++a是先赋值在运算!! 先看a++的代码哦 class demo1 { ...

  8. c#与java中byte字节的区别及转换方法

    原文:c#与java中byte字节的区别及转换方法 在java中  byte的范围在 [-128,127] 在C#中  byte的范围在 [0,255] 所以 java程序与C#程序 进行数据传输的时 ...

  9. java中==与equel的区别

    值类型是存储在内存中的堆栈(以后简称栈),而引用类型的变量在栈中仅仅是存储引用类型变量的地址,而其本身则存储在堆中. ==操作比较的是两个变量的值是否相等,对于引用型变量表示的是两个变量在堆中存储的地 ...

随机推荐

  1. kubernetes 之一些报错

    1.kubelet与docker的Cgroup Driver不一致导致的报错 7月 :: kubeadm-master kubelet[]: W0701 :: watcher.go:] Error w ...

  2. git同步本地数据到github——第一次使用和以后使用

    git作为版本控制工具十分的好用,但是在使用的过程中,会因为仓库版本的不同步出现很多错误 一.git简单的原理交互模型 从下面的model中我们看到在不创建分支情况下始终是远程的origin和本地的m ...

  3. 端口快速扫描程序(c#版 一次可发起1000个连接)

    前言 为了探测本机或对方开放了哪些端口,需要用到端口扫描程序.扫描端口的原理很简单:就是尝试连接对方:如果成功,对方就开放了此端口.扫描程序的关键是速度,如果一次只能发起几个连接,显然速度太慢.如果对 ...

  4. C#工具类SqlServerHelper,基于System.Data.SqlClient封装

    源码: using System; using System.Collections.Generic; using System.Data; using System.Linq; using Syst ...

  5. 动手动脑,第六次Tutorial——数组和随机数数组输出及求和

    作业课后作业1 阅读QiPan.java示例程序了解如何利用二维数组和循环语句绘制五子棋盘. 首先,定义string类型的二维数组,它和类的数组不一样,类的数组分配了空间后不能直接for循环赋值,st ...

  6. maven 学习---Maven构建生命周期

    构建生命周期是一组阶段的序列(sequence of phases),每个阶段定义了目标被执行的顺序.这里的阶段是生命周期的一部分. 举例说明,一个典型的 Maven 构建生命周期是由以下几个阶段的序 ...

  7. sql server 安装出现需要sqlncli.msi文件,错误为 microsoft sql server 2012 native client

    在安装sql server 2017 时出现 弹框标题为  microsoft sql server 2012 native client  内容为需要sqlncli.msi文件 去本地目录找本身的那 ...

  8. Apache:系统找不到指定的文件: No installed ConfigArgs for the service "Apache2"

    解决方法: 将以下内容保存成FixApacheError.reg文件(其中红色粗体Apache2改成报错的系统服务名称,如"RTX_HTTPServer"),导入系统注册表 Fix ...

  9. tensorflow模型量化实例

    1,概述 模型量化应该是现在最容易实现的模型压缩技术,而且也基本上是在移动端部署的模型的毕竟之路.模型量化基本可以分为两种:post training quantizated和quantization ...

  10. jmeter压测学习7-登录参数化(CSV 数据文件设置)

    前言 我们在压测登录接口的时候,如果只用一个账号去设置并发压测,这样的结果很显然是不合理的,一个用户并发无法模拟真实的情况. 如果要压测登录接口,肯定得准备几百,甚至上千的账号去登录,测试的结果才具有 ...