在Java中,有幾種常見的方法可以實(shí)現(xiàn)單例模式:
public class Singleton {
private static Singleton instance;
private Singleton() {
}
public static Singleton getInstance() {
if (instance == null) {
instance = new Singleton();
}
return instance;
}
}
這種實(shí)現(xiàn)方式在多線程環(huán)境下是不安全的,可能會(huì)創(chuàng)建多個(gè)實(shí)例。
public class Singleton {
private static volatile Singleton instance;
private Singleton() {
}
public static Singleton getInstance() {
if (instance == null) {
synchronized (Singleton.class) {
if (instance == null) {
instance = new Singleton();
}
}
}
return instance;
}
}
這種實(shí)現(xiàn)方式在多線程環(huán)境下是安全的,但是效率較低。
public class Singleton {
private static final Singleton instance = new Singleton();
private Singleton() {
}
public static Singleton getInstance() {
return instance;
}
}
這種實(shí)現(xiàn)方式在類加載時(shí)就創(chuàng)建實(shí)例,所以不會(huì)浪費(fèi)資源,但是類加載較慢時(shí)可能會(huì)導(dǎo)致啟動(dòng)時(shí)間較長。
public class Singleton {
private Singleton() {
}
private static class SingletonHolder {
private static final Singleton INSTANCE = new Singleton();
}
public static Singleton getInstance() {
return SingletonHolder.INSTANCE;
}
}
這種實(shí)現(xiàn)方式利用了Java的靜態(tài)內(nèi)部類特性,既保證了線程安全,又實(shí)現(xiàn)了懶加載。
public enum Singleton {
INSTANCE;
public void doSomething() {
// ...
}
}
這種實(shí)現(xiàn)方式利用了Java的枚舉特性,既保證了線程安全,又實(shí)現(xiàn)了懶加載。這是實(shí)現(xiàn)單例模式的最佳實(shí)踐。