一 般情況下,如果有些代碼必須在項目啟動的時候就執行的時候,需要使用靜態代碼塊,這種代碼是主動執行的;需要在項目啟動的時候就初始化,在不創建對象的情 況下,其他程序來調用的時候,需要使用靜態方法,這種代碼是被動執行的. 靜態方法在類加載的時候 就已經加載 可以用類名直接調用比如main方法就必須是靜態的 這是程序入口兩者的區別就是:靜態代碼塊是自動執行的;靜態方法是被調用的時候才執行的.區別很簡單:靜態代碼塊,在虛擬機加載類的時候就會加載執行,而且只執行一次;非靜態代碼塊,在創建對象的時候(即new一個對象的時候)執行,每次創建對象都會執行一次相同點:都是在JVM加載類時且在構造方法執行之前執行,在類中都可以定義多個, 一般在代碼塊中對一些static變量進行賦值。不同點:靜態代碼塊在非靜態代碼塊之前執行(靜態代碼塊—>非靜態代碼塊—>構造方法)。 靜態代碼塊只在第一次new執行一次,之后不再執行,而非靜態代碼塊在每new 一次就執行一次。非靜態代碼塊可在普通方法中定義(不過作用不大);而靜態代碼塊不行。例://普通類public class PuTong {public PuTong(){System.out.PRint("默認構造方法!-->");}//非靜態代碼塊{System.out.print("非靜態代碼塊!-->");}//靜態代碼塊static{System.out.print("靜態代碼塊!-->");}public static void test(){{System.out.println("普通方法中的代碼塊!");}}}//測試類public class TestClass {/*** 區別兩次new靜態與非靜態代碼塊執行情況*/public static void main(String[] args) {PuTong c1 = new PuTong();c1.test();PuTong c2 = new PuTong();c2.test();}}/*運行輸出結果是:靜態代碼塊!-->非靜態代碼塊!-->默認構造方法!-->普通方法中的代碼塊!非靜態代碼塊!-->默認構造方法!-->普通方法中的代碼塊!*/繼承的時候:分析:對象的初始化順序:首先執行父類靜態的內容,父類靜態的內容執行完畢后,接著去執行子類的靜態的內容,當子類的靜態內容執行完畢之后,再去看父類有沒有非靜態代碼塊,如果有就執行父類的非靜態代碼塊,父類的非靜態代碼塊執行完畢,接著執行父類的構造方法;父類的構造方法執行完畢之后,它接著去看子類有沒有非靜態代碼塊,如果有就執行子類的非靜態代碼塊。子類的非靜態代碼塊執行完畢再去執行子類的構造方法。總之一句話,靜態代碼塊內容先執行,接著執行父類非靜態代碼塊和構造方法,然后執行子類非靜態代碼塊和構造方法。 而且子類的構造方法,不管這個構造方法帶不帶參數,默認的它都會先去尋找父類的不帶參數的構造方法。如果父類沒有不帶參數的構造方法,那么子類必須用supper關鍵子來調用父類帶參數的構造方法,否則編譯不能通過。
新聞熱點
疑難解答