这是在网上找的知识点

覆盖方法必须满足的条件:

1)子类方法的名称、参数签名和返回类型必须与父类方法的名称、参数签名和返回类型一致,修饰符可以相同也可以不同,但子类的访问权限不能低于父类的访问权限。

class Aball {

Aball() {

}

public void method() {

}

}

===============================================================================================

public class ExtendsMethod extends Aball {

ExtendsMethod() {

}

public void method() {//覆盖父类的方法

}

public int method(int i) {//重载类中的方法

i++;

return i;

}

}

==============================================================================================

2)子类方法不能缩小父类方法的访问权限

3)子类方法不能抛出比父类方法更多的异常。子类方法抛出的异常必须和父类方法抛出的异常相同,或者子类方法抛出的异常类是父类方法抛出的异常类的子类。另外,写抛出异常catch块时,子类方法抛出的异常在父类方法抛出异常的前面。

4)方法覆盖只存在于子类和父类(包括直接父类和间接父类)之间。在同一个类中方法只能被重载,不能被覆盖。

5)父类的静态方法不能被子类覆盖为非静态方法。

6)子类可以定义与父类的静态方法同名的静态方法,以便在子类中隐藏父类的静态方法。(静态方法只能隐藏,不能覆盖)

子类隐藏父类的静态方法和子类覆盖父类的实例方法区别:运行时,JVM把静态方法和所属的类绑定,而把实例方法和所属的实例绑定。

class Aball {

Aball() {

}

void method() {

System.out.println("method of Aball");

}

static void staticmethod() {

System.out.println("staticmethod of Aball");

}

}

public class ExtendsMethod extends Aball {

ExtendsMethod() {

}

void method() {// 覆盖父类的方法

System.out.println("method of ExtendsMethod");

}

===============================================================================================

static void staticmethod() {// 重载类中的方法

System.out.println("staticmethod of ExtendsMethod");

}

===============================================================================================

public static void main(String[] args) {

Aball sub1 = new ExtendsMethod();

ExtendsMethod sub2 = new ExtendsMethod();

sub1.method();

sub1.staticmethod();

sub2.method();

sub2.staticmethod();

}

}

结果为:

method of ExtendsMethod

staticmethod of Aball

method of ExtendsMethod

staticmethod of ExtendsMethod

引用变量sub1和sub2都引用ExtendsMethod类的实例,执行sub1.method()和sub2.method()时,都调用ExtendsMethod实例的method()方法,此时父类Aball的实例方法method()被子类覆盖。

引用变量sub1被声明为Aball类型,执行sub1.staticmethod()时,调用Aball类的staticmethod()方法,说明父类的静态方法不能被子类覆盖。

引用变量sub2被声明为ExtendsMethod类型,执行sub2.staticmethod()时,调用ExtendsMethod类的staticmethod()方法,说明父类的静态方法被子类的静态方法隐藏了。

7)父类的非静态方法不能被子类覆盖为静态方法。

8)父类的私有方法不能被子类覆盖。

class Aball {

Aball() {

}

===============================================================================================

private String method() {

return "Aball";

}

===============================================================================================

void print() {

System.out.println(method());

}

}

===============================================================================================

public class ExtendsMethod extends Aball {

ExtendsMethod() {

}

===============================================================================================

public String method() {// 覆盖父类的方法

return "ExtendsMethod";

}

===============================================================================================

public static void main(String[] args) {

Aball sub1 = new Aball();

ExtendsMethod sub2 = new ExtendsMethod();

sub1.print();

sub2.print();

}

}

结果为:

Aball

Aball

执行sub2.print()方法时,因为print()方法在Aball类中定义,因此Aball方法会调用在Aball类中定义的private类型的method()方法。

把Aball类的method()方法改为public类型,期他代码不变,

则运行结果为

Aball

ExtendsMethod

原因是由于ExtendsMethod中的method()方法覆盖了Aball类中的method()方法,执行sub2.print()时,JVM会调用当前ExtendsMethod实例的method()方法。

9)父类的抽象方法可以被子类通过两种途径覆盖:一是子类实现父类的抽象方法;二是子类重新声明父类的抽象方法。

abstract class Aball {

Aball() {

}

abstract void method();

abstract void print();

}

===============================================================================================

public abstract class ExtendsMethod extends Aball {

ExtendsMethod() {

}

public void method() {// 实现method()方法,并扩大访问权限

}

// 重新声明print()方法,并扩大访问权限,但不实现

public abstract void print();

}

10)父类的非抽象方法可以被覆盖为抽象方法。

abstract class Aball {

Aball() {

}

void method() {

}

void print() {

}

}

===============================================================================================

public abstract class ExtendsMethod extends Aball {

ExtendsMethod() {

}

public void method() {// 覆盖父类的method()方法

}

// 覆盖父类的print()方法

public abstract void print();

}

37.引用变量类型转换

Animal animal=new Dog();

Dog dog=(Dog)animal;//向下转型,把Animal类型转换为Dog类型

Creature creature=animal;//向上转型,把Animal类型转换为Creature类型

Dog继承Animal,Animal继承Creature

38.

修饰符

成员方法

构造方法

成员变量

局部变量

absstract(抽象的)

static(静态的)

public(公共的)

protected(受保护的)

private(私有的)

synchronized(同步的)

native(本地的)

transient(暂时的)

volatile(易失的)

final(不可改变的)

修饰顶层类的修饰符包括abstract、public、final,而static、protected、private不能修饰顶层类。

最新文章

  1. 说说js作用域
  2. 基础编程-java之股神
  3. C++11模板类使用心得
  4. python--基础学习(六)sqlite数据库基本操作
  5. 测试必备技能系列4:如何用SSH向linux服务器上传下载文件
  6. [译]Node.js Best Practices - Part 2
  7. Coursera台大机器学习技法课程笔记04-Soft-Margin Support Vector Machine
  8. 深入浅出:Linux设备驱动之字符设备驱
  9. 【转】CocoaPods的安装以及遇到的坑
  10. 001-python基础
  11. IOS流媒体播放
  12. linux下svn用法
  13. fineui webform
  14. 基于Python玩转人工智能最火框架 TensorFlow应用实践
  15. Flume+Kafka整合
  16. npm 安装nodesass 或者包含nodesass的脚手架工具报错问题
  17. B/S架构中常用弹出方法 (转)
  18. <cctype>库
  19. JS面向对象编程学习
  20. vscode Gitlens插件 查看代码提交

热门文章

  1. OpenBSD内核之引导MBR
  2. php时间设置为本地
  3. Python笔记总结week3
  4. <context:component-scan>使用说明
  5. c# 获取 本周、本月、本季度、本年 的开始时间或结束时间
  6. 运维之netstat
  7. Python之路,Day6 - 面向对象学习
  8. maven pom.xml
  9. 2014 NOIP 赛前自我整理提醒。
  10. <java基础学习>01环境变量配置