您好,登錄后才能下訂單哦!
這篇文章主要講解了Java靜態(tài)代碼塊是如何執(zhí)行的,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。
一般情況下,如果有些代碼必須在項目啟動的時候就執(zhí)行,需要使用靜態(tài)代碼塊。這種代碼是主動執(zhí)行的,需要在項目啟動的時候就初始化。
有些代碼是在不創(chuàng)建對象的情況下,由其他程序來調用,需要使用靜態(tài)方法。這種代碼是被動執(zhí)行的。 靜態(tài)方法在類加載的時候就已經加載,可以用類名直接調用
比如main方法就必須是靜態(tài)的 這是程序入口
兩者的區(qū)別就是:靜態(tài)代碼塊是自動執(zhí)行的,而靜態(tài)方法是被調用的時候才執(zhí)行的。
區(qū)別很簡單:
靜態(tài)代碼塊,在虛擬機加載類的時候就會加載執(zhí)行,而且只執(zhí)行一次;
非靜態(tài)代碼塊,在創(chuàng)建對象的時候(即new一個對象的時候)執(zhí)行,每次創(chuàng)建對象都會執(zhí)行一次
相同點:都是在JVM加載類時且在構造方法執(zhí)行之前執(zhí)行,在類中都可以定義多個,
一般在代碼塊中對一些static變量進行賦值。
不同點:靜態(tài)代碼塊在非靜態(tài)代碼塊之前執(zhí)行(靜態(tài)代碼塊—>非靜態(tài)代碼塊—>構造方法)。
靜態(tài)代碼塊只在第一次類加載時執(zhí)行一次,之后不再執(zhí)行,而非靜態(tài)代碼塊在每new
一次就執(zhí)行一次。非靜態(tài)代碼塊可在普通方法中定義(不過作用不大);而靜態(tài)代碼塊不行。
例:
//普通類 public class PuTong { public PuTong(){ System.out.print("默認構造方法!-->"); } //非靜態(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(); } } /* 運行輸出結果是: 靜態(tài)代碼塊!-->非靜態(tài)代碼塊!-->默認構造方法!-->普通方法中的代碼塊! 非靜態(tài)代碼塊!-->默認構造方法!-->普通方法中的代碼塊! */
繼承的時候:
分析:對象的初始化順序:首先執(zhí)行父類靜態(tài)的內容,父類靜態(tài)的內容執(zhí)行完畢后,接著去執(zhí)行子類的靜態(tài)的內容,當子類的靜態(tài)內容執(zhí)行完畢之后,再去看父類有沒有非靜態(tài)代碼塊,
如果有就執(zhí)行父類的非靜態(tài)代碼塊,父類的非靜態(tài)代碼塊執(zhí)行完畢,接著執(zhí)行父類的構造方法;父類的構造方法執(zhí)行完畢之后,它接著去看子類有沒有非靜態(tài)代碼塊,如果有就執(zhí)行子類的非靜態(tài)代碼塊。
子類的非靜態(tài)代碼塊執(zhí)行完畢再去執(zhí)行子類的構造方法??傊痪湓?,靜態(tài)代碼塊內容先執(zhí)行,接著執(zhí)行父類非靜態(tài)代碼塊和構造方法,然后執(zhí)行子類非靜態(tài)代碼塊和構造方法。
而且子類的構造方法,不管這個構造方法帶不帶參數(shù),默認的它都會先去尋找父類的不帶參數(shù)的構造方法。如果父類沒有不帶參數(shù)的構造方法,那么子類必須用supper關鍵子來調用父類帶參數(shù)的構造方法,否則編譯不能通過。
看完上述內容,是不是對Java靜態(tài)代碼塊是如何執(zhí)行的有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業(yè)資訊頻道。
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。