1. 能否夠重寫靜態方法
假設從重寫方法會有什么特點來看,我們是不能重寫靜態方法的。盡管就算你重寫靜態方法,編譯器也不會報錯。也就是說,假設你試圖重寫靜態方法,Java不會阻止你這么做,但你卻得不到預期的結果(重寫僅對非靜態方法實用)。重寫指的是依據執行時對象的類型來決定調用哪個方法,而不是依據編譯時的類型。讓我們猜一猜為什么靜態方法是比較特殊的?由於它們是類的方法,所以它們在編譯階段就使用編譯出來的類型進行綁定了。使用對象引用來訪問靜態方法僅僅是Java設計者給程序猿的自由。我們應該直接使用類名來訪問靜態方法,而不要使用對象引用來訪問。
讓我們看一個樣例,來看看重寫靜態方法會發生什么:
class SuperClass{ ...... public static void staticMethod(){ System.out.println("SuperClass: inside staticMethod"); } ...... } public class SubClass extends SuperClass{ ...... //overriding the static method public static void staticMethod(){ System.out.println("SubClass: inside staticMethod"); } ...... public static void main(String []args){ ...... SuperClass superClassWithSuperCons = new SuperClass(); SuperClass superClassWithSubCons = new SubClass(); SubClass subClassWithSubCons = new SubClass(); superClassWithSuperCons.staticMethod(); superClassWithSubCons.staticMethod(); subClassWithSubCons.staticMethod(); ... } }
輸出:
<pre name="code" class="java">SuperClass: inside staticMethod SuperClass: inside staticMethod SubClass: inside staticMethod
注意第二行輸出。如果staticMethod方法被重寫了,它的結果應該和第三行一樣,也是調用執行時的類型SubClass的staticMethod(),而不是SuperClass的staticMethod()方法。這也就證明了靜態方法是在編譯階段使用了編譯類型信息,進行靜態綁定的。
2.synchronizedkeyword是不能繼承的,也就是說,基類的方法synchronized f(){} 在繼承類中並不自己主動是synchronized f(){},而是變成了f(){}。繼承類須要你顯式的指定它的某個方法為synchronized方法;