• JAVA面向对象学习——java面向对象概念———重写


                                          重写(Override)

    重写是子类对父类的允许访问的方法的实现过程进行重新编写, 返回值和形参都不能改变即外壳不变,核心重写!

    重写的好处在于子类可以根据需要,定义特定于自己的行为。 也就是说子类能够根据需要实现父类的方法。

    重写方法不能抛出新的检查异常或者比被重写方法申明更加宽泛的异常。

    例如: 父类的一个方法申明了一个检查异常 IOException,但是在重写这个方法的时候不能抛出 Exception 异常,

                 因为 Exception 是 IOException 的父类,抛出 IOException 异常或者 IOException 的子类异常。

    在面向对象原则里,重写意味着可以重写任何现有方法。

    方法的重写规则

    • 参数列表与被重写方法的参数列表必须完全相同。

    • 返回类型与被重写方法的返回类型可以不相同,但是必须是父类返回值的派生类(java5 及更早版本返回类型要一样,java7 及更高版本可以不同)。

    • 访问权限不能比父类中被重写的方法的访问权限更低。例如:如果父类的一个方法被声明为 public,那么在子类中重写该方法就不能声明为 protected。

    • 父类的成员方法只能被它的子类重写。

    • 声明为 final 的方法不能被重写。

    • 声明为 static 的方法不能被重写,但是能够被再次声明。

    • 子类和父类在同一个包中,那么子类可以重写父类所有方法,除了声明为 private 和 final 的方法。

    • 子类和父类不在同一个包中,那么子类只能够重写父类的声明为 public 和 protected 的非 final 方法。

    • 重写的方法能够抛出任何非强制异常,无论被重写的方法是否抛出异常。但是,重写的方法不能抛出新的强制性异常,或者比被重写方法声明的更广泛的强制性异常,反之则可以。

    • 构造方法不能被重写。

    • 如果不能继承一个类,则不能重写该类的方法。

    示例:

    class Animal
    {
        public void move()
        {
            System.out.println("动物可以移动");
        }
    }
    
    class Dog extends Animal
    {
        public void move()
        {
            System.out.println("狗可以跑和走");
        }
    
        public void bark()
        {
            System.out.println("狗可以叫");
        }
    }
    
    public class TestDog
    {
        public static void main(String args[])
        {
            Animal a = new Animal();
    
            Dog b = new Dog();
    
            a.move();
            b.move();
            b.bark();
        }
    }
    

      

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

    示例:

    class Animal
    {
        public void move()
        {
            System.out.println("动物可以移动");
        }
    }
    
    class Dog extends Animal
    {
        public void move()
        {
            System.out.println("狗可以跑和走");
        }
    
        public void bark()
        {
            System.out.println("狗可以叫");
        }
    }
    
    public class TestDog
    {
        public static void main(String args[])
        {
            Animal a = new Animal();
    
            Animal b = new Dog();
    
            a.move();
            b.move();
    
        }
    }
    

    在上面的例子中可以看到,尽管 b 属于 Animal 类型,但是它运行的是 Dog 类的 move方法。

    这是由于在编译阶段,只是检查参数的引用类型。

    然而在运行时,Java 虚拟机(JVM)指定对象的类型并且运行该对象的方法。

    因此在上面的例子中,之所以能编译成功,是因为 Animal 类中存在 move 方法,然而运行时,运行的是特定对象的方法。

    我们已经讨论了方法的重写,也就是子类能够重写父类的方法。

    当子类对象调用重写的方法时,调用的是子类的方法,而不是父类中被重写的方法。

    要想调用父类中被重写的方法,则必须使用关键字 super

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

    示例:

    class Animal
    {
        public void move()
        {
            System.out.println("动物可以移动");
        }
    }
    
    class Dog extends Animal
    {
        public void move()
        {
            System.out.println("狗可以跑和走");
        }
    
        public void bark()
        {
            System.out.println("狗可以叫");
        }
    }
    
    public class TestDog
    {
        public static void main(String args[])
        {
            Animal a = new Animal();
    
            Animal b = new Dog();
    
            a.move();
            b.move();
            b.bark();
        }
    }
    

      

    该程序将抛出一个编译错误,因为b的引用类型Animal没有bark方法。

    解释核心:多态—— 当使用多态方式调用方法时,首先检查父类中是否有该方法,如果没有,则编译错误;如果有,再去调用子类的同名方法。

  • 相关阅读:
    spring boot 启动后执行初始化方法
    Linux CentOS 7 下 JDK 安装与配置
    Linux rpm 命令参数使用详解[介绍和应用]
    异常处理: 重载Throwable.fillInStackTrace方法已提高Java性能
    dubbo 配置属性
    centos7 操作防火墙
    springBoot 打包 dubbo jar包
    直播中聊天场景的用例分享
    解决在安装Fiddler4.6版本后,在手机上安装证书出现的问题解决方法
    系统调优方案思路分享
  • 原文地址:https://www.cnblogs.com/xiaobaibailongma/p/15836407.html
Copyright © 2020-2023  润新知