深入java虚拟机学习 -- 类的加载机制(续)
昨晚寫?深入java虛擬機學習 -- 類的加載機制?都到1點半了,由于第二天還要工作,沒有將上篇文章中的demo講解寫出來,今天抽時間補上昨晚的例子講解。
這里我先把昨天的兩份代碼貼過來,重新看下:
class Singleton {private static Singleton singleton = new Singleton(); //第一份代碼的位置public static int counter1;public static int counter2=0;private static Singleton singleton = new Singleton();//第二份代碼的位置private Singleton(){counter1++;counter2++;}public static Singleton getInstance(){return singleton;} }public class Demo {public static void main(String[] args){Singleton singleton=Singleton.getInstance();System.out.println("counter1:"+singleton.counter1);System.out.println("counter2:"+singleton.counter2);} }第一份代碼執行結果:
第二份代碼執行結果:
類是如何被加載的
讓我們再來回顧下上篇文章的加載順序
我們知道Java虛擬機為類的靜態變量分配內存,并設置默認的初始值實在準備階段開始的,這里所設置的初始值通常情況下是類型默認的零值(如0、0L、null、false等),而不是被在Java代碼中被顯式地賦予的值。有很多人還是不太明白默認零值和顯示賦值到底是什么意思,下面我們距離來說:
public class Sample{private static int a=1;private static int b; }上面的代碼在經過了準備階段后的結果是:
a=0; b=0;大家可能對b=0沒有任何疑問,而a=0;就是上面說的“類型默認的零值”,也就是說準備的階段等號右邊的1并不會賦值給a,不知道這么解釋大家能不能明白,而類初始化階段是類加載過程的最后一步,到了初始化階段,才真正開始執行類中定義的java程序代碼。在初始化階段,Java虛擬機執行類的初始化語句,為類的靜態變量?賦予正確的初始值。
private static int a=1; 表示a被顯式初始化成1;private static int b; 這里的b并沒有被顯式初始化,所以此時b的值仍然為0;
案例分析
好了,說了這么多開始分析案例,我們知道類是自上而下執行的,所以第一份代碼解析如下
第二份代碼是將1->2->3的順序修改為2->3->1,我們按著上面的思路重新分析發現很清晰的就知道了結果
準備階段沒有任何變化,counter1=0、counter2=0;
初始化階段,counter1沒有被顯式賦值,所以counter1仍然保留值0,counter2被顯式賦值為0,所以counter2=0,到第三步時調用了Singleton()方法,此時執行了++操作
最終結果 counter1:1、counter2:1
?
轉載于:https://www.cnblogs.com/blueskyli/p/8487774.html
總結
以上是生活随笔為你收集整理的深入java虚拟机学习 -- 类的加载机制(续)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: NOI2013矩阵游戏
- 下一篇: 运送超级计算机 蓝书368