java创建具体时间点_java单例饿汉模式对象创建时间点疑问
關(guān)于java單例中餓漢式模式的解釋,大多如下:
餓漢模式線程安全的,在類創(chuàng)建的同時(shí)就已經(jīng)創(chuàng)建好一個(gè)靜態(tài)的對(duì)象,相對(duì)與懶漢模式對(duì)象創(chuàng)建過(guò)早,浪費(fèi)空間。
但是jvm中明確定義是:虛擬機(jī)規(guī)范則是嚴(yán)格規(guī)定了有且只有5種情況必須立即對(duì)類進(jìn)行“初始化”
1)遇到new、getstatic、putstatic或invokestatic這4條字節(jié)碼指令時(shí),如果類沒有進(jìn)行過(guò)初始化,則需要先觸發(fā)其初始化。
2)使用java.lang.reflect包的方法對(duì)類進(jìn)行反射調(diào)用的時(shí)候,如果類沒有進(jìn)行過(guò)初始化,則需要先觸發(fā)其初始化。
3)當(dāng)初始化一個(gè)類的時(shí)候,如果發(fā)現(xiàn)其父類還沒有進(jìn)行過(guò)初始化,則需要先觸發(fā)其父類的初始化。
4)當(dāng)虛擬機(jī)啟動(dòng)時(shí),用戶需要指定一個(gè)要執(zhí)行的主類(包含main()方法的那個(gè)類),虛擬機(jī)會(huì)先初始化這個(gè)主類。
5)當(dāng)使用JDK 1.7的動(dòng)態(tài)語(yǔ)言支持時(shí),如果一個(gè)java.lang.invoke.MethodHandle實(shí)例最后的解析結(jié)果REF_get-Static、REF_putStatic、REF_invokeStatic的方法句柄,并且這個(gè)方法句柄所對(duì)應(yīng)的類沒有進(jìn)行過(guò)初始化,則需要先觸發(fā)其初始化。
public class Singleton {
private static Singleton instance = new Singleton();
private Singleton (){}
public static Singleton getInstance() {
return instance;
}
}
根據(jù)第1)條可知道,只有調(diào)用單例模式的getInstance的時(shí)候,才會(huì)初始化instance字段。
寫了個(gè)例子來(lái)驗(yàn)證這點(diǎn):
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();
}
}
執(zhí)行main方法后的結(jié)果是:
null
new signleton
上面的例子可以看出,在調(diào)用getInstance方法的時(shí)候,jvm才會(huì)對(duì)SingletonTest類初始化。
問(wèn)題:在不使用反射模式加載單例類的情況下,懶漢模式和餓漢模式有區(qū)別嗎?
總結(jié)
以上是生活随笔為你收集整理的java创建具体时间点_java单例饿汉模式对象创建时间点疑问的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 为什么电脑没有A盘和B盘?
- 下一篇: oracle exp执行失败,Oracl