Java靜態(tài)代碼塊作用及執(zhí)行順序解析
一般情況下,如果有些代碼必須在項目啟動的時候就執(zhí)行,需要使用靜態(tài)代碼塊。這種代碼是主動執(zhí)行的,需要在項目啟動的時候就初始化。
有些代碼是在不創(chuàng)建對象的情況下,由其他程序來調(diào)用,需要使用靜態(tài)方法。這種代碼是被動執(zhí)行的。 靜態(tài)方法在類加載的時候就已經(jīng)加載,可以用類名直接調(diào)用
比如main方法就必須是靜態(tài)的 這是程序入口
兩者的區(qū)別就是:靜態(tài)代碼塊是自動執(zhí)行的,而靜態(tài)方法是被調(diào)用的時候才執(zhí)行的。
區(qū)別很簡單:
靜態(tài)代碼塊,在虛擬機加載類的時候就會加載執(zhí)行,而且只執(zhí)行一次;
非靜態(tài)代碼塊,在創(chuàng)建對象的時候(即new一個對象的時候)執(zhí)行,每次創(chuàng)建對象都會執(zhí)行一次
相同點:都是在JVM加載類時且在構(gòu)造方法執(zhí)行之前執(zhí)行,在類中都可以定義多個,
一般在代碼塊中對一些static變量進行賦值。
不同點:靜態(tài)代碼塊在非靜態(tài)代碼塊之前執(zhí)行(靜態(tài)代碼塊—>非靜態(tài)代碼塊—>構(gòu)造方法)。
靜態(tài)代碼塊只在第一次類加載時執(zhí)行一次,之后不再執(zhí)行,而非靜態(tài)代碼塊在每new
一次就執(zhí)行一次。非靜態(tài)代碼塊可在普通方法中定義(不過作用不大);而靜態(tài)代碼塊不行。
例:
//普通類public class PuTong {public PuTong(){System.out.print('默認構(gòu)造方法!-->');}//非靜態(tài)代碼塊{System.out.print('非靜態(tài)代碼塊!-->');}//靜態(tài)代碼塊static{System.out.print('靜態(tài)代碼塊!-->');}public static void test(){{System.out.println('普通方法中的代碼塊!');}}}//測試類public class TestClass {/*** 區(qū)別兩次new靜態(tài)與非靜態(tài)代碼塊執(zhí)行情況*/public static void main(String[] args) {PuTong c1 = new PuTong();c1.test();PuTong c2 = new PuTong();c2.test();}}/*運行輸出結(jié)果是:靜態(tài)代碼塊!-->非靜態(tài)代碼塊!-->默認構(gòu)造方法!-->普通方法中的代碼塊!非靜態(tài)代碼塊!-->默認構(gòu)造方法!-->普通方法中的代碼塊!*/
繼承的時候:
分析:對象的初始化順序:首先執(zhí)行父類靜態(tài)的內(nèi)容,父類靜態(tài)的內(nèi)容執(zhí)行完畢后,接著去執(zhí)行子類的靜態(tài)的內(nèi)容,當子類的靜態(tài)內(nèi)容執(zhí)行完畢之后,再去看父類有沒有非靜態(tài)代碼塊,
如果有就執(zhí)行父類的非靜態(tài)代碼塊,父類的非靜態(tài)代碼塊執(zhí)行完畢,接著執(zhí)行父類的構(gòu)造方法;父類的構(gòu)造方法執(zhí)行完畢之后,它接著去看子類有沒有非靜態(tài)代碼塊,如果有就執(zhí)行子類的非靜態(tài)代碼塊。
子類的非靜態(tài)代碼塊執(zhí)行完畢再去執(zhí)行子類的構(gòu)造方法。總之一句話,靜態(tài)代碼塊內(nèi)容先執(zhí)行,接著執(zhí)行父類非靜態(tài)代碼塊和構(gòu)造方法,然后執(zhí)行子類非靜態(tài)代碼塊和構(gòu)造方法。
而且子類的構(gòu)造方法,不管這個構(gòu)造方法帶不帶參數(shù),默認的它都會先去尋找父類的不帶參數(shù)的構(gòu)造方法。如果父類沒有不帶參數(shù)的構(gòu)造方法,那么子類必須用supper關(guān)鍵子來調(diào)用父類帶參數(shù)的構(gòu)造方法,否則編譯不能通過。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
