关于继承中(静态方法+私有方法)的覆盖与重写问题

//关于继承中(静态方法+私有方法)的覆盖与重写问题
public class SuperCla {

//父类中的静态方法
public static int staMet(String str){
    System.out.println("父类中的静态方法");
    System.out.println("参数是"+str);
    return 0;
}

private void priMet(){
    System.out.println("父类中的私有方法");
}

}

package firstExam.biShi_test;

public class SubCla {
/*
* 注意:父类的静态方法不能被重写,即方法①前不能加@Override重写标志;
* 但是可以如代码②一样,在子类中实现父类的静态方法的覆盖;
* 大致解释如下:静态方法只与定义时所在的类相关,在编译期间就已经绑定到某个类,
* 对于static的静态方法,只有继承,重载与隐藏,没有重写。
*
@Override
public static int staMet(String str){—–①
System.out.println(“我是子类的要覆盖父类的静态方法”);
System.out.println(“参数是”+str);
return 0;
}
*/

public static int staMet(String str){//-----②
    System.out.println("我是子类的要覆盖父类的静态方法");
    System.out.println("参数是"+str);
    return 0;
}

/*
* 注意:父类的私有方法不能被重写,即方法③前不能加@Override重写标志;
* 但是可以如代码④一样,在子类中实现父类的私有方法的覆盖;
*
* 注意:一个类的私有方法是不能被重写的,因为私有方法不能被子类访问。子类在继承的时候,
* 只有public和protected修饰的方法才可以被重写;
* 对于子类不可见的private成员,以及没有被访问修饰符修饰的默认类成员(如果子类与父类在不同的包中,
* 这一类的类成员也是对子类不可见的),他们对于子类不可见,但是当创建了子类的实例的时候,这些成员一样
* 会被加载入内存,并“隐藏”在内存中。
*
@Override
private void priMet(){—-③
System.out.println(“父类中的私有方法”);
}
*/

private void priMet(){//----④
    System.out.println("父类中的私有方法");
}
public static void main(String[] args) {
    SuperCla superCla=new SuperCla();
    superCla.staMet("一曦");
    SubCla subCla=new SubCla();
    subCla.staMet("莫离");



}

}

猜你喜欢

转载自blog.csdn.net/qq_38986609/article/details/78609212
今日推荐