zoukankan      html  css  js  c++  java
  • Java基础一

    这是在网上找的知识点

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

      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不能修饰顶层类。
  • 相关阅读:
    iOS 开发网络篇—监测网络状态
    再杀掉app之后 删除NSUserDefault存在本地的数据
    iOS开发之duplicate symbols for architecture x86_64错误
    iOS中UITextField输入判断小数点后两位
    ios 适配iOS11&iPhoneX的一些坑
    iOS UITextView 设置 NSLinkAttributeName 属性,点击链接跳转
    iOS- UITextView与键盘回收与键盘遮挡输入框
    iOS 实现单个页面支持横竖屏,其他页面只能竖屏
    iOS最新Mac OS X 10.11之后 安装cocoapods及使用详解
    一种简单的登录加密方案
  • 原文地址:https://www.cnblogs.com/BestFeng/p/JavaFirst.html
Copyright © 2011-2022 走看看