Java靜態程式碼塊作用及執行順序解析
一般情況下,如果有些程式碼必須在專案啟動的時候就執行,需要使用靜態程式碼塊。這種程式碼是主動執行的,需要在專案啟動的時候就初始化。
有些程式碼是在不建立物件的情況下,由其他程式來呼叫,需要使用靜態方法。這種程式碼是被動執行的。 靜態方法在類載入的時候就已經載入,可以用類名直接呼叫
比如main方法就必須是靜態的 這是程式入口
兩者的區別就是:靜態程式碼塊是自動執行的,而靜態方法是被呼叫的時候才執行的。
區別很簡單:
靜態程式碼塊,在虛擬機器載入類的時候就會載入執行,而且只執行一次;
非靜態程式碼塊,在建立物件的時候(即new一個物件的時候)執行,每次建立物件都會執行一次
相同點:都是在JVM載入類時且在構造方法執行之前執行,在類中都可以定義多個,
一般在程式碼塊中對一些static變數進行賦值。
不同點:靜態程式碼塊在非靜態程式碼塊之前執行(靜態程式碼塊—>非靜態程式碼塊—>構造方法)。
靜態程式碼塊只在第一次類載入時執行一次,之後不再執行,而非靜態程式碼塊在每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關鍵子來呼叫父類帶引數的構造方法,否則編譯不能通過。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。