Java深入理解代碼塊的使用細(xì)節(jié)
1.基本介紹
代碼塊又稱(chēng)為初始化塊,屬于類(lèi)中的成員(類(lèi)的一部分),類(lèi)似于方法,講邏輯語(yǔ)句封裝在方法體中,用{}抱起來(lái);
但和方法不同,沒(méi)有方法名,沒(méi)有返回,沒(méi)有參數(shù),只有方法體,而且不用通過(guò)對(duì)象或類(lèi)顯式調(diào)用。
基本語(yǔ)法
(修飾符)(可有可無(wú)){代碼};
注:
1.修飾符可選,要寫(xiě)只能寫(xiě)static
2.代碼塊可分為兩類(lèi),使用static修飾的叫靜態(tài)代碼塊,沒(méi)有static修飾的叫普通代碼塊。
3.;可有可無(wú)
好處
1.相當(dāng)于另一種形式的構(gòu)造器,可以做初始化的操作
2.如果多個(gè)構(gòu)造器中都有重復(fù)的語(yǔ)句,可以抽取到代碼塊中。
快速入門(mén)
package com.demo.codeblock_;
public class codeblock01 {
public static void main(String[] args) {
movie m01=new movie("環(huán)太平洋");
movie m02=new movie("荒野大飛",66);
movie m03=new movie("無(wú)暇赴死",55,"老K");
}
}
class movie{
private String name;
private double price;
private String director;
{
System.out.println("電影屏幕打開(kāi)。。。");
System.out.println("廣告開(kāi)始。。。");
System.out.println("電影開(kāi)始。。。");
}
//三個(gè)構(gòu)造器重載
public movie(String name) {
// System.out.println("電影屏幕打開(kāi)。。。");
// System.out.println("廣告開(kāi)始。。。");
// System.out.println("電影開(kāi)始。。。");
System.out.println("構(gòu)造器movie(String name)被調(diào)用。。。");
this.name = name;
}
public movie(String name, double price) {
// System.out.println("電影屏幕打開(kāi)。。。");
// System.out.println("廣告開(kāi)始。。。");
// System.out.println("電影開(kāi)始。。。");
System.out.println("構(gòu)造器movie(String name, double price)被調(diào)用。。。");
this.name = name;
this.price = price;
}
public movie(String name, double price, String director) {
// System.out.println("電影屏幕打開(kāi)。。。");
// System.out.println("廣告開(kāi)始。。。");
// System.out.println("電影開(kāi)始。。。");
System.out.println("構(gòu)造器movie(String name, double price, String director)被調(diào)用。。。");
this.name = name;
this.price = price;
this.director = director;
}
}
2.代碼塊細(xì)節(jié)
代碼塊使用注意事項(xiàng)和細(xì)節(jié)討論
1)static代碼塊也叫靜態(tài)代碼塊,作用就是對(duì)類(lèi)進(jìn)行初始化,而且它隨著類(lèi)的加載而執(zhí)行,并且只會(huì)執(zhí)行一次。如果是普通代碼塊,每創(chuàng)建一個(gè)對(duì)象,就執(zhí)行。
2)類(lèi)什么時(shí)候被加載[重要!]
①創(chuàng)建對(duì)象實(shí)例時(shí)(new)
②創(chuàng)建子類(lèi)對(duì)象實(shí)例,父類(lèi)也會(huì)被加載
③使用類(lèi)的靜態(tài)成員時(shí)(靜態(tài)屬性,靜態(tài)方法)
案例演示:A 類(lèi) extends B類(lèi)的靜態(tài)塊
3)普通的代碼塊,在創(chuàng)建對(duì)象實(shí)例時(shí),會(huì)被隱式的調(diào)用。 被創(chuàng)建一次,就會(huì)調(diào)用一次。 如果只是使用類(lèi)的靜態(tài)成員時(shí),普通代碼塊并不會(huì)執(zhí)行。
package com.demo.codeblock_;
public class codeblock02 {
public static void main(String[] args) {
//類(lèi)被加載的情況舉例
//1.創(chuàng)建對(duì)象時(shí)new
//AA aa=new AA();
//2.創(chuàng)建子類(lèi)對(duì)象實(shí)例,父類(lèi)也會(huì)被加載,而且,父類(lèi)先被加載,子類(lèi)后被加載
AA aa01=new AA();
//3.使用類(lèi)的靜態(tài)成員時(shí)
System.out.println(cat.n);
DD d1=new DD();
DD d2=new DD();
}
}
class DD{
static {
System.out.println("DD的靜態(tài)代碼被執(zhí)行1次");
}
}
class animal{
static {
System.out.println("animal的靜態(tài)代碼被執(zhí)行");
}
}
class cat extends animal{
public static int n=888;
//靜態(tài)代碼塊
static {
System.out.println("cat的靜態(tài)代碼塊被執(zhí)行");
}
}
class BB {
static {
System.out.println("BB的靜態(tài)代碼被執(zhí)行");
}
}
class AA extends BB{
static {
System.out.println("AA的靜態(tài)代碼被執(zhí)行");
}
}

類(lèi)的調(diào)用順序
創(chuàng)建一個(gè)對(duì)象時(shí),在一個(gè)類(lèi)調(diào)用順序:(重點(diǎn)、難點(diǎn))
①調(diào)用靜態(tài)代碼塊和靜態(tài)屬性初始化 ( 注意:靜態(tài)代碼塊和靜態(tài)屬性初始化調(diào)用的優(yōu)先級(jí)一樣,如果有多個(gè)靜態(tài)代碼塊和多個(gè)靜態(tài)變量初始化,則按他們定義的順序調(diào)用)
②調(diào)用普通代碼塊和普通屬性的初始化 ( 注意:普通代碼塊和普 通屬性初始化調(diào)用的優(yōu)先級(jí)一樣,如果有多個(gè)普通代碼塊和多 不普通屬性初始化,則按定義順序調(diào)用)
③調(diào)用構(gòu)造方法。
實(shí)例
package com.demo.codeblock_;
public class codeblock03 {
public static void main(String[] args) {
A a=new A();
}
}
class A{
public A(){
System.out.println("A的無(wú)參構(gòu)造被調(diào)用");
}
int n2=getn2();
{//普通代碼塊
System.out.println("A的普通代碼塊被調(diào)用");
}
int getn2(){
System.out.println("getn2被調(diào)用");
return 99;
}
private static int n=getn();
static {
System.out.println("A的靜態(tài)代碼被調(diào)用");
}
public static int getn(){
System.out.println("getn被調(diào)用");
return 100;
}
}
代碼塊細(xì)節(jié)2
構(gòu)造器的最前面其實(shí)隱含了 super(和調(diào)用普通代碼塊,新寫(xiě)一個(gè)類(lèi)演示靜態(tài)相關(guān)的代碼塊,屬性初始化,在類(lèi)加載時(shí),就執(zhí)行完畢
,因此是優(yōu)先于構(gòu)造器和普通代碼塊執(zhí)行的
class A {
public AO{
super0:
//調(diào)用普通代碼塊
_System.out.println("ok");
}
}實(shí)例
package com.demo.codeblock_;
public class codeblock04 {
public static void main(String[] args) {
B b=new B();
}
}
class AA{
{
System.out.println("AA的普通代碼塊");
}
public AA(){
//1.super()
//2.調(diào)用本類(lèi)的普通代碼塊
System.out.println("AA的構(gòu)造器被調(diào)用");
}
}
class B extends AA{
{
System.out.println("B的普通代碼塊");
}
public B(){
//1.super()
//2.調(diào)用本類(lèi)的普通代碼塊
System.out.println("B的構(gòu)造器被調(diào)用");
}
}
代碼塊細(xì)節(jié)2
我們看一下創(chuàng)建一個(gè)子類(lèi)對(duì)象時(shí)(繼承關(guān)系),他們的靜態(tài)代碼塊,靜態(tài)屬性初 始化,普通代碼塊,普通屬性初始化,構(gòu)造方法的調(diào)用順序如下:
1.父類(lèi)的靜態(tài)代碼塊和靜態(tài)屬性(優(yōu)先級(jí)一樣,按定義順序熱行
2.子類(lèi)的靜態(tài)代碼塊和靜態(tài)屬性(優(yōu)先級(jí)一樣,按定義順序執(zhí)行)
3.父類(lèi)的普通代碼塊和普通屬性初始化(優(yōu)先級(jí)一樣,按定義順序執(zhí)行)
4.父類(lèi)的構(gòu)造方法
5.子類(lèi)的普通代碼塊和普通屬性初始化(優(yōu)先級(jí)一樣,按定義順序執(zhí)行)
6.子類(lèi)的構(gòu)造方法
7.靜態(tài)代碼塊只能直接調(diào)用靜態(tài)成員(靜態(tài)屬性和靜態(tài)方法),普通代碼塊可以調(diào) 用任意成員。
實(shí)例
package com.demo.codeblock_;
public class codeblock05 {
public static void main(String[] args) {
//老師說(shuō)明
//(1) 進(jìn)行類(lèi)的加載
//1.1 先加載 父類(lèi) A02 1.2 再加載 B02
//(2) 創(chuàng)建對(duì)象
//2.1 從子類(lèi)的構(gòu)造器開(kāi)始
//new B02();//對(duì)象
new C02();
}
}
class A02 { //父類(lèi)
private static int n1 = getVal01();
static {
System.out.println("A02的一個(gè)靜態(tài)代碼塊..");//(2)
}
{
System.out.println("A02的第一個(gè)普通代碼塊..");//(5)
}
public int n3 = getVal02();//普通屬性的初始化
public static int getVal01() {
System.out.println("getVal01");//(1)
return 10;
}
public int getVal02() {
System.out.println("getVal02");//(6)
return 10;
}
public A02() {//構(gòu)造器
//隱藏
//super()
//普通代碼和普通屬性的初始化......
System.out.println("A02的構(gòu)造器");//(7)
}
}
class C02 {
private int n1 = 100;
private static int n2 = 200;
private void m1() {
}
private static void m2() {
}
static {
//靜態(tài)代碼塊,只能調(diào)用靜態(tài)成員
//System.out.println(n1);錯(cuò)誤
System.out.println(n2);//ok
//m1();//錯(cuò)誤
m2();
}
{
//普通代碼塊,可以使用任意成員
System.out.println(n1);
System.out.println(n2);//ok
m1();
m2();
}
}
class B02 extends A02 { //
private static int n3 = getVal03();
static {
System.out.println("B02的一個(gè)靜態(tài)代碼塊..");//(4)
}
public int n5 = getVal04();
{
System.out.println("B02的第一個(gè)普通代碼塊..");//(9)
}
public static int getVal03() {
System.out.println("getVal03");//(3)
return 10;
}
public int getVal04() {
System.out.println("getVal04");//(8)
return 10;
}
//一定要慢慢的去品..
public B02() {//構(gòu)造器
//隱藏了
//super()
//普通代碼塊和普通屬性的初始化...
System.out.println("B02的構(gòu)造器");//(10)
// TODO Auto-generated constructor stub
}
}
到此這篇關(guān)于Java深入理解代碼塊的使用細(xì)節(jié)的文章就介紹到這了,更多相關(guān)Java代碼塊內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java并發(fā)編程學(xué)習(xí)之ThreadLocal源碼詳析
這篇文章主要給大家介紹了關(guān)于Java并發(fā)編程學(xué)習(xí)之源碼分析ThreadLocal的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-06-06
使用Java實(shí)現(xiàn)先查詢(xún)緩存再查詢(xún)數(shù)據(jù)庫(kù)
這篇文章主要介紹了使用Java實(shí)現(xiàn)先查詢(xún)緩存再查詢(xún)數(shù)據(jù)庫(kù),文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-07-07
使用Java實(shí)現(xiàn)三種等級(jí)的掃雷游戲(完整版)
掃雷是一款大眾類(lèi)的益智小游戲,根據(jù)點(diǎn)擊格子出現(xiàn)的數(shù)字找出所有非雷格子,同時(shí)避免踩雷,踩到一個(gè)雷即全盤(pán)皆輸,下面這篇文章主要給大家介紹了關(guān)于使用Java實(shí)現(xiàn)三種等級(jí)的掃雷游戲的相關(guān)資料,需要的朋友可以參考下2023-01-01
Java加密 消息摘要算法MAC實(shí)現(xiàn)詳解
這篇文章主要介紹了Java 消息摘要算法MAC實(shí)現(xiàn)詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-07-07
詳解Java編程中if...else語(yǔ)句的嵌套寫(xiě)法
這篇文章主要介紹了Java編程中if...else語(yǔ)句的嵌套寫(xiě)法,是Java入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-11-11
springboot prototype設(shè)置多例不起作用的解決操作
這篇文章主要介紹了springboot prototype設(shè)置多例不起作用的解決操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09
Java面試必備之AQS阻塞隊(duì)列和條件隊(duì)列
我們大概知道AQS就是一個(gè)框架,把很多功能都給實(shí)現(xiàn)了(比如入隊(duì)規(guī)則,喚醒節(jié)點(diǎn)中的線(xiàn)程等),我們?nèi)绻褂玫脑?huà)只需要實(shí)現(xiàn)其中的一些方法(比如tryAcquire等)就行了!這次主要說(shuō)說(shuō)AQS中阻塞隊(duì)列的的入隊(duì)規(guī)則還有條件變量,需要的朋友可以參考下2021-06-06
Java中四種9*9乘法表的實(shí)現(xiàn)方式(附代碼)
這篇文章主要介紹了Java中四種9*9乘法表的實(shí)現(xiàn)方式(附代碼),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11
SpringMVC源碼之HandlerMapping處理器映射器解析
這篇文章主要介紹了SpringMVC源碼之HandlerMapping處理器映射器解析,在Spring?MVC中,HandlerMapping處理器映射器用于確定請(qǐng)求處理器對(duì)象,請(qǐng)求處理器可以是任何對(duì)象,只要它們使用了@Controller注解或注解@RequestMapping,需要的朋友可以參考下2023-08-08

