午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術文章
文章詳情頁

類加載機制 - java單例餓漢模式對象創建時間點疑問

瀏覽:196日期:2023-12-24 13:13:50

問題描述

關于java單例中餓漢式模式的解釋,大多如下:餓漢模式線程安全的,在類創建的同時就已經創建好一個靜態的對象,相對與懶漢模式對象創建過早,浪費空間。

但是jvm中明確定義是:虛擬機規范則是嚴格規定了有且只有5種情況必須立即對類進行“初始化”

1)遇到new、getstatic、putstatic或invokestatic這4條字節碼指令時,如果類沒有進行過初始化,則需要先觸發其初始化。2)使用java.lang.reflect包的方法對類進行反射調用的時候,如果類沒有進行過初始化,則需要先觸發其初始化。3)當初始化一個類的時候,如果發現其父類還沒有進行過初始化,則需要先觸發其父類的初始化。4)當虛擬機啟動時,用戶需要指定一個要執行的主類(包含main()方法的那個類),虛擬機會先初始化這個主類。5)當使用JDK 1.7的動態語言支持時,如果一個java.lang.invoke.MethodHandle實例最后的解析結果REF_get-Static、REF_putStatic、REF_invokeStatic的方法句柄,并且這個方法句柄所對應的類沒有進行過初始化,則需要先觸發其初始化。

public class Singleton {

private static Singleton instance = new Singleton(); private Singleton (){} public static Singleton getInstance() { return instance; }

}

根據第1)條可知道,只有調用單例模式的getInstance的時候,才會初始化instance字段。

寫了個例子來驗證這點:

public class SingletonTest {

private static SingletonTest singleton=new SingletonTest();private SingletonTest(){ System.out.println('new signleton');}public static SingletonTest getSingleton(){ return singleton;}

}

public class Test {

public static void main(String args[]){ SingletonTest singleton=null; System.out.println(singleton); singleton= SingletonTest.getSingleton();}

}

執行main方法后的結果是:

null

new signleton

上面的例子可以看出,在調用getInstance方法的時候,jvm才會對SingletonTest類初始化。

問題:在不使用反射模式加載單例類的情況下,懶漢模式和餓漢模式有區別嗎?

問題解答

回答1:

.net 程序員一枚。你在SingletonTest 類中加個靜態字段,不調用getSingleton,直接調用這個字段,看看輸出什么。

還有不要死記單例模式的三種模式,一定要理解,然后才能靈活運用這三個模式。

標簽: java
相關文章:
主站蜘蛛池模板: 欧美综合成人 | 久久精品91 | 亚洲tv在线观看 | 欧美精品网址 | 亚洲一区 在线播放 | 在线播放成人av | 中文字幕一区二区三区在线观看 | 亚洲v在线观看 | 久久久久久久久久免费视频 | 亚洲高清视频在线播放 | 免费av网站在线 | 一级片大全 | 欧美福利小视频 | 国产一区二区免费视频 | 国产三级短视频 | 一级特黄aa大片欧美 | 狠狠综合| 久久一区二区三区四区五区 | 麻豆精品在线视频 | 日韩精品四区 | 国产精品五月天 | 一级特黄特色的免费大片视频 | 久久一级大片 | 自拍偷拍第一页 | 五月激情六月 | 黄网址在线观看 | 操碰91 | 国产精品短视频 | 国产精品自产拍 | 五月综合色婷婷 | 91国产在线免费观看 | 蜜臀av性久久久久蜜臀aⅴ四虎 | 国产精品爽| 欧美 日韩 精品 | 国产午夜精品在线观看 | 天天色天天 | 搜索黄色一级片 | 毛片毛片毛片毛片毛片毛片毛片 | 亚洲欧洲色图 | 久久久在线观看 | 亚洲国产欧美另类 |