能否夠重寫靜態方法


    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方法;

 
        


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM