java常见小错误(四):JAVA静态方法是否可以被继承
java常见错误系列文章
下一篇:java常见小错误(三):内部类的隐式“闭包”
往期文章推荐:
java小技巧(三):JAVA 交集,差集,并集
java小技巧(二):进制转换
java常见小错误(一):变量类型自动转换与强制转换
java常见小错误(二):Java迭代器iterator和for循环的区别
【版权申明】未经博主同意,谢绝转载!(请尊重原创,博主保留追究权);
本博客的内容来自于:java常见小错误(四):JAVA静态方法是否可以被继承;
学习、合作与交流联系q384660495;
本博客的内容仅供学习与参考,并非营利;
结论:java中静态属性和静态方法可以被继承,但是没有被重写(overwrite)而是被隐藏.
原因:
- 静态方法和属性是属于类的,调用的时候直接通过类名.方法名完成对,不需要继承机制及可以调用。如果子类里面定义了静态方法和属性,那么这时候父类的静态方法或属性称之为"隐藏"。如果你想要调用父类的静态方法和属性,直接通过父类名.方法或变量名完成,至于是否继承一说,子类是有继承静态方法和属性,但是跟实例方法和属性不太一样,存在"隐藏"的这种情况。
- 多态之所以能够实现依赖于继承、接口和重写、重载(继承和重写最为关键)。有了继承和重写就可以实现父类的引用指向不同子类的对象。重写的功能是:"重写"后子类的优先级要高于父类的优先级,但是“隐藏”是没有这个优先级之分的。
- 静态属性、静态方法和非静态的属性都可以被继承和隐藏而不能被重写,因此不能实现多态,不能实现父类的引用可以指向不同子类的对象。非静态方法可以被继承和重写,因此可以实现多态。
实验如下:
//父类
class Father{
public static String str = "Father类中的静态属性";
public String s = "Father中的非静态属性";
public static void fun(){
System.out.println("Father类中的静态方法");
}
public void f(){
System.out.println("Father中的非静态方法");
}
}
class Child1 extends Father
{
public static String str = "Child1改写Father中的静态属性";
public String s = "Child1改写Father中的非静态属性";
public static void fun(){
System.out.println("Child1改写Father中的静态方法");
}
public void f(){
System.out.println("Child1改写Father中的非静态方法");
}
}
//完全继承,不修改
class Child2 extends Father
{
}
//定义测试类
public class TestExtends
{
public static void main(String[] args){
System.out.println("*****************Child2 ch1 = new Child2() 完全继承******************");
//用子类实例化子类
Child2 ch1 = new Child2();
System.out.println(ch1.str);
System.out.println(ch1.s);
ch1.fun();
ch1.f();
System.out.println("*****************Father ch2 = new Child2() 完全继承 多态******************");
//用父类引用指向子类对象
Father ch2 = new Child2();
System.out.println(ch2.str);
System.out.println(ch2.s);
ch2.fun();
ch2.f();
System.out.println("***************Child1 ch3 = new Child1()(Child1中修改了)********************");
Child1 ch3 = new Child1();
System.out.println(ch3.str);
System.out.println(ch3.s);
ch3.fun();
ch3.f();
System.out.println("*****************Father ch4 = new Child1()(Child1中修改了) 多态******************");
//用父类引用指向子类对象
Father ch4 = new Child1();
System.out.println(ch4.str);
System.out.println(ch4.s);
ch4.fun();
ch4.f();
}
}
实验结果: