java入栈_java中代码块的执行,也会有入栈的步骤吗?
首先這個問題很有意思,不過題主沒具體指明放在何處的代碼塊。
這里至少有三種情況,第一種就是在普通的方法里面,第二種是實例初始化代碼塊,第三種是靜態初始化代碼塊。
第一種情況
使用javap反匯編了一下有代碼塊的代碼和無代碼塊的代碼。結果比較后發現它們居然是一樣的。
public class HelloWorld {
public void main(String[] args) {
int n = 1;
System.out.println(n);
// {int m = 2;
System.out.println(m);
// }}
}
然后執行一下javac HelloWorld.java && javap -c HelloWorld看匯編代碼
public class HelloWorld {
public HelloWorld();
Code:
0: aload_0
1: invokespecial #1 // Method java/lang/Object."":()V
4: return
public void main(java.lang.String[]);
Code:
0: iconst_1
1: istore_2
2: getstatic #2 // Field java/lang/System.out:Ljava/io/PrintStream;
5: iload_2
6: invokevirtual #3 // Method java/io/PrintStream.println:(I)V
9: iconst_2
10: istore_3
11: getstatic #2 // Field java/lang/System.out:Ljava/io/PrintStream;
14: iload_3
15: invokevirtual #3 // Method java/io/PrintStream.println:(I)V
18: return
}
所以我得出結論,普通代碼塊僅是詞法語法層面的,對運行時沒有影響,也就是說不存在所謂的「進入代碼塊入棧保存程序狀態,出代碼塊再通過出棧來恢復程序狀態」這種只有函數代碼塊才會出現的步驟。
第二種情況
實例初始化代碼塊里面的代碼會被自動添加到「所有的構造器」的開頭,代碼塊本身無額外壓棧彈棧操作。而且要注意的是,這里說的是「所有的構造器」,有幾個構造器,匯編代碼中就會出現多少的冗余片段。如果有很多構造器,那就會有相當的浪費。
public class UserDB {
private Map rows = new HashMap<>();
{
rows.put("Linus", "linux");
rows.put("Neumann", "math");
rows.put("Turing", "gay");
}
public boolean checkAccess(String name, String passwd) {
return rows.containsKey(name) && rows.get(name).equals(passwd);
}
}
第三種情況
靜態代碼塊是一個非常特殊的代碼塊,編譯器會將同一個類中所有的靜態代碼塊合并成一個函數static{},它們共享一次壓棧彈棧操作。
public class UserDB {
private static Map rows = new HashMap<>();
static {
rows.put("Linus", "linux");
rows.put("Neumann", "math");
rows.put("Turing", "gay");
}
public boolean checkAccess(String name, String passwd) {
return rows.containsKey(name) && rows.get(name).equals(passwd);
}
}
總結
以上是生活随笔為你收集整理的java入栈_java中代码块的执行,也会有入栈的步骤吗?的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 战双帕弥什自抽号怎么使用_战双帕弥什新S
- 下一篇: java控制台高级_K9s Kubern