java继承方法规则或规律

方法的继承与属性的继承有很大的不同,属性任何继承方式均可,而方法则有各种限制,于是在这里做了一个简单的总结:

1、修饰符相同的方法覆盖,即只改内部,不改外部

2、访问权限不同的方法覆盖,子类只能相对父类越来越宽松,例如父类是public,子类就不能是缺省或protect,private

3、返回值的类型覆盖,只允许相容的返回类型,例如不能将返回值为int型改为double型,但是复合类型则例外

4、final的方法覆盖,只能是父类无,子类有,而不能是父类有,子类无

5、static(静态)的方法覆盖不能有任何变动,即父类有,子类必须有,父类无,子类也必须无

实例如下:

父类:

 

package ExtendMethod;

public class CommonMethod {
    protected int x=100;
    public int getX() {//定义一个普通返回值的实例方法
        return x;
    }
    public CommonMethod getObject() {//定义一个返回复合类型的方法
        return new CommonMethod();
    }
    public final void setX(int ix) {
        x=ix;
    }
    protected  void proShowMsg() {//定义一个具有保护权限的方法
        System.out.println("this is protected ShowMsg() in Common class");
    }
    
    public void pubShowMsg() {//定义一个具有公共访问权限的方法
        System.out.println("this is public showMsg() in Common class");
    }
    static public void stShowMsg() {//定义一个静态方法
        System.out.println("this is static showMsg() in Common class");
    }
}

 

一、修饰符相同的可以任意覆盖:

public class OverrideMember_1 extends Common{
    //覆盖父类中的同名实例方法
    public void pubShowMsg() {
        System.out.println("this is public showMsg in derive class");
    }
    //覆盖父类中的同名静态方法
    static public void stShowMsg() {
        System.out.println("this is static showMsg() in derive class");
    }
    //可以任意覆盖
    public static void main(String args[]) {
        OverrideMember_1 oa =new OverrideMember_1();
        oa.pubShowMsg();
        oa.proShowMsg();
    }
}

二、访问权限不同的覆盖,只能越来越宽松,private——>public的方向

public class OverrideMember_2 extends Common{
    public void proShowMsg() {//覆盖父类中的protect方法,public > protect,正确
        System.out.println("this is public ShowMsg()");
    }
    /*protected void pubShowMsg() {//权限越来越严格,错误,protect < public
        System.out.println("this is protect ShowMsg()");
    }*/
}

三、返回值类型的覆盖

public class OverrideMember_3 extends Common {
    //覆盖getX()方法,但返回的数据类型不同,原方法是int型,错误
    /*public double getX() {
        return (double)x;
    }*/
    //覆盖getObject(),返回类型相容,正确,原方法的返回类型是新common对象,复合类型
    public OverrideMember_3 getObject() {
        return new OverrideMember_3();
    }
}

四、final的方法覆盖,只能从无到有,不能从有到无

public class OverrideMember_4 extends Common{
    //覆盖getX()方法,并将其指定为最终方法,正确,原方法为public int getX()
    public final int  getX() {
        return x;
    }
    //覆盖最终方法,错误,原方法为 public final void setX()
    /*public void setX(int ix) {
        x=ix;
    }*/
}

五、static不能有任何改变

public class OverrideMember_5 extends Common{
    //试图覆盖实例方法,将其改为静态方法,错误,原型为 public void pubShowMsg()
    /*public static void pubShowMsg() {
        System.out.println("this is public ShowMsg()");
    }*/
    //试图覆盖静态方法,并将其指定为实例方法,错误
    /*public void stShowMsg() {
        System.out.println("this is static ShowMsg()");
    }*/
}
//总结,静态与实例之间不能相互转换

 

posted @ 2018-03-12 16:06  沉默的赌徒  阅读(8998)  评论(0编辑  收藏  举报