首先結論是: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();//結果都是父類的靜態方法,說明靜態方法不可以被重寫,不能實現多態
}
}