java中静态属性和和静态方法的继承问题 以及多态的实质

首先结论是:java中静态属性和和静态方法可以被继承,但是没有被重写(overwrite)而是被隐藏。

静态方法和属性是属于类的,调用的时候直接通过类名.方法名完成的,不需继承机制就可以调用如果子类里面定义了静态方法和属性,那么这时候父类的静态方法 或属性称之为“隐藏”,你如果想要调用父类的静态方法和属性,直接通过父类名.方法名或变量名完成,至于是否继承一说,子类是有继承静态方法和属性,但是 跟实例方法和属性不太一样,存在“隐藏”的这种情况。

多态之所以能够实现是依赖于 继承 接口和 重写 、重载(继承和重写最为关键)。有了继承和重写就可以  实现父类的引用可以指向不同子类的对象。重写的功能是:“重写”后子类的优先级要高于父类的优先级,但是“隐藏”是没有这个优先级之分的。

静态属性、静态方法和非静态的属性都可以被 继承 和 隐藏  而不能够被重写,因此不能实现多态,不能实现父类的引用可以指向不同子类的对象。       非静态的方法可以被继承和重写,因此可以实现多态。
##接口中的实现和类中的继承是两个不同的概念,因此不可以说实现接口的子类从接口那里继承了常量和方法
例证如下:
package com.etc;
public  class A//父类
{
    public static String str = "静态属性";
    public String name = "非静态属性";
    public static void sing()
    {
        System.out.println("静态方法");
    }
   
    public void run()
    {
        System.out.println("非静态方法");
    }
}
package com.etc;
public class B extends A //子类B
{
    public static String str = "B该改写后的静态属性";
    public String name ="B改写后的非静态属性";
    public static void sing()
    {
        System.out.println("B改写后的静态方法");
    }
}
package com.etc;
public class C extends A //子类C继承A中的所有属性和方法
{
}
package com.etc;
public class Test//测试类
{
    public static void main(String[] args)
    {
        C c = new C();
        System.out.println(c.name);
        System.out.println(c.str);
        c.sing();//输出的结果都是父类中的非静态属性、静态属性和静态方法,推出静态属性和静态方法可以被继承
       
        A c1 = new C();
        System.out.println(c1.name);
        System.out.println(c1.str);
        c1.sing();//结果同上,输出的结果都是父类中的非静态属性、静态属性和静态方法,推出静态属性和静态方法可以被继承
       
        B b = new B();
        System.out.println(b.name);
        System.out.println(b.str);
        b.sing();//结果都是子类的非静态属性,静态属性和静态方法,这里和非静态属性和非静态类的继承相同
       
       
        A b1 = new B();
        System.out.println(b1.str);//结果是父类的静态属性,说明静态属性不可以被重写,不能实现多态
        System.out.println(b1.name);//结果是父类的非静态属性,说明非静态属性不可以被重写,不能实现多态
        b1.sing();//结果都是父类的静态方法,说明静态方法不可以被重写,不能实现多态
    }
}

posted @ 2016-02-04 16:54  kabibo  阅读(6481)  评论(0编辑  收藏  举报