像這樣的情況,自己動手測試下,比誰說的都有說服力!
10年積累的成都網(wǎng)站設計、成都做網(wǎng)站經(jīng)驗,可以快速應對客戶對網(wǎng)站的新想法和需求。提供各種問題對應的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡服務。我雖然不認識你,你也不認識我。但先網(wǎng)站設計制作后付款的網(wǎng)站建設流程,更有龍山免費網(wǎng)站建設讓你可以放心的選擇與我們合作。
通過測試,可以看的出靜態(tài)代碼塊之間是平級的,按照順序在執(zhí)行的!
順序執(zhí)行,就是正常情況下
選擇執(zhí)行(分支),就是用if else...可以使用多次,還有個switch? case
循環(huán)執(zhí)行,常用的用for循環(huán),while循環(huán),do while循環(huán)
就我理解題意好像就這三種
靜態(tài)初始化塊:當類第一次加載時執(zhí)行。
非靜態(tài)初始化塊:非靜態(tài)初始化塊會在構造函數(shù)執(zhí)行時,且在構造函數(shù)主體代碼執(zhí)行之前被執(zhí)行。
區(qū)別如下:
1、執(zhí)行次數(shù)不同
靜態(tài)塊只執(zhí)行一次,初始化塊可以執(zhí)行多次。
2、作用不同
靜態(tài)初始化塊僅能初始化類變量,即static修飾的數(shù)據(jù)成員。
非靜態(tài)初始化塊可以初始化類的實例變量。
擴展資料:
使用Java靜態(tài)代碼塊注意事項:
1、它是隨著類的加載而執(zhí)行,只執(zhí)行一次,并優(yōu)先于主函數(shù)。具體說,靜態(tài)代碼塊是由類調用的。類調用時,先執(zhí)行靜態(tài)代碼塊,然后才執(zhí)行主函數(shù)的。
2、靜態(tài)代碼塊其實就是給類初始化的,而構造代碼塊是給對象初始化的。
3、靜態(tài)代碼塊中的變量是局部變量,與普通函數(shù)中的局部變量性質沒有區(qū)別。
4、一個類中可以有多個靜態(tài)代碼塊。
5、對于靜態(tài)變量、靜態(tài)初始化塊、變量、初始化塊、構造器,它們的初始化順序依次是(靜態(tài)變量、靜態(tài)初始化塊)(變量、初始化塊)構造器。
java中首先是靜態(tài)塊先執(zhí)行,靜態(tài)方法,最后是構造函數(shù)。示例如下:
public?class?ExA?{??
static?{??
System.out.println("父類--靜態(tài)代碼塊");??
}??
public?ExA()?{??
System.out.println("父類--構造函數(shù)");??
}??
{??
System.out.println("父類--非靜態(tài)代碼塊");??
}??
public?static?void?main(String[]?args)?{??
new?ExB();??
}??
}??
class?ExB?extends?ExA?{??
static?{??
System.out.println("子類--靜態(tài)代碼塊");??
}??
{??
System.out.println("子類--非靜態(tài)代碼塊");??
}??
public?ExB()?{??
System.out.println("子類--構造函數(shù)");??
}??
}??
執(zhí)行結果?
=====?
父類--靜態(tài)代碼塊?
子類--靜態(tài)代碼塊?
父類--非靜態(tài)代碼塊?
父類--構造函數(shù)?
子類--非靜態(tài)代碼塊?
子類--構造函數(shù)
因為普通成員變量相比構造方法不管順序優(yōu)先加載
java 初始化順序:
靜態(tài)成員變量靜態(tài)初始化塊普通成員變量普通的初始化塊構造方法(自動初始化時機在調用任何方法之前(構造方法,成員方法))
在創(chuàng)建新的對象時,也就是new一個對象時,會開始初始化這個對象,在初始化這個對象時,會找到對應的類,如果類中有static的靜態(tài)方法,靜態(tài)成員變量,普通變量。。。等,會按照這個順序執(zhí)行(即按照這個順序分配內(nèi)容空間,不管他們的位置在哪里,如果是同類型,則按照上下順序執(zhí)行。)
先后順序如下!
1.靜態(tài)塊
2.塊
3.構造器
4.父類構造器
運行順序為:
1. 靜態(tài)塊
2. 父類構造器
3. 本類中的塊
4. 本類的構造器