1. 局部代碼塊
創(chuàng)新互聯(lián)建站專注于同安企業(yè)網(wǎng)站建設,成都響應式網(wǎng)站建設,商城開發(fā)。同安網(wǎng)站建設公司,為同安等地區(qū)提供建站服務。全流程按需設計,專業(yè)設計,全程項目跟蹤,創(chuàng)新互聯(lián)建站專業(yè)和態(tài)度為您提供的服務
作用在方法當中,作用是控制變量的生命周期:
public void show(){
{
System.out.println("局部代碼塊運行!");
}
}123456
在程序中當我們定義完成一個局部變量x之后,并且在接下來的代碼中,不想再用到它時,那么就沒必要讓x在內存中繼續(xù)占用空間。因此就有了局部代碼塊。
2. 構造代碼塊
作用在類的定義Body中,作用是給類的部分字段統(tǒng)一初始化:
public class Apple {
private String size;
//構造代碼塊
{
System.out.println("構造代碼塊運行!");
size = "E";
}
}
12345678910
構造代碼塊與構造函數(shù)的區(qū)別是:構造代碼塊是給所有對象進行統(tǒng)一初始化,而構造函數(shù)是給對應的對象初始化,因為構造函數(shù)是可以多個的,運行哪個構造函數(shù)就會建立什么樣的對象,但無論建立哪個對象,都會先執(zhí)行相同的構造代碼塊。也就是說,構造代碼塊中定義的是不同對象共性的初始化內容。所以理所當然的,構造代碼塊在構造函數(shù)之前執(zhí)行。
3. 靜態(tài)代碼塊
作用有兩個:
(1)給類的靜態(tài)變量賦值;
(2)聲明靜態(tài)變量;
作用在類的Body中,對類中的靜態(tài)變量初始化:
public class APP {
static int x, y; // 靜態(tài)變量
static {
x = 5; // 給靜態(tài)變量x賦值
}
public static void myMethod() {
y = x++ + ++x; // x++ 先使用x的值再加1;++x先加1再使用x的值
}
public static void main(String[] args) {
x--;
myMethod();
System.out.println(x + y + ++x);
}
}
輸出:23
其實n是聲明過了的。類加載的時候先加載靜態(tài)成員函數(shù),然后再加載靜態(tài)變量。加載變量的時候先執(zhí)行聲明一塊,也就是static int m; static int n; static int i; 根據(jù)靜態(tài)成員變量m, n 和i都會被默認賦值為0,這個時候m,n,i都被聲明了;然后再依次執(zhí)行m=n=foo(); n=goo(); i=10;的賦值。
非靜態(tài)變量也測試過了,好像就是這么個理O(∩_∩)O
java中有四種代碼塊
1.普通代碼塊:直接在{}中出現(xiàn)的。
2.構造代碼塊:在構造函數(shù)的{}中出現(xiàn)的。
3.靜態(tài)代碼塊:static{}中出現(xiàn)的。
4.同步代碼塊:多線程中出現(xiàn)。
這個是因為你的代碼寫在匿名內部類里面,java在類里只允許聲明成員變量和函數(shù),是不能直接寫代碼的。
代碼邏輯應該寫在函數(shù)內部。