1.懒汉式
线程不安全,如果两个线程同时执行到了
if (instance == null) {//这一句判断都为真,紧接着就会创建两个实例
public class Singleton {
private static Singleton instance;
private Singleton (){}
public static Singleton getInstance() {
if (instance == null) {
instance = new Singleton();
}
return instance;
}
}
public class Singleton {
private static Singleton instance;
private Singleton (){}
public static synchronized Singleton getInstance() { //对方法枷锁性能不高
if (instance == null) {
instance = new Singleton();
}
return instance;
}
}线程安全的,double-check
public class Singleton {
private volatile static Singleton singleton;
private Singleton (){}
public static Singleton getSingleton() {
if (singleton == null) {
synchronized (Singleton.class) {
if (singleton == null) {
singleton = new Singleton();
}
}
}
return singleton;
}
}
public class Singleton {
private static Singleton instance = new Singleton();
private Singleton (){}
public static Singleton getInstance() {
return instance;
}
} 3.静态内部类,jvm在调用getInstance()时才会进行类的初始化
public class Singleton {
private static class SingletonHolder {
private static final Singleton INSTANCE = new Singleton();
}
private Singleton (){}
public static final Singleton getInstance() {
return SingletonHolder.INSTANCE;
}
} 4.通过枚举实现,枚举实例的创建时线程安全的,并且对序列化有保证
public enum Singleton {
INSTANCE;
public void whateverMethod() {
}
}
1.懒汉式
线程不安全,如果两个线程同时执行到了
if (instance == null) {//这一句判断都为真,紧接着就会创建两个实例
public class Singleton {
private static Singleton instance;
private Singleton (){}
public static Singleton getInstance() {
if (instance == null) {
instance = new Singleton();
}
return instance;
}
}
public class Singleton {
private static Singleton instance;
private Singleton (){}
public static synchronized Singleton getInstance() { //对方法枷锁性能不高
if (instance == null) {
instance = new Singleton();
}
return instance;
}
}线程安全的,double-check
public class Singleton {
private volatile static Singleton singleton;
private Singleton (){}
public static Singleton getSingleton() {
if (singleton == null) {
synchronized (Singleton.class) {
if (singleton == null) {
singleton = new Singleton();
}
}
}
return singleton;
}
}
public class Singleton {
private static Singleton instance = new Singleton();
private Singleton (){}
public static Singleton getInstance() {
return instance;
}
} 3.静态内部类,jvm在调用getInstance()时才会进行类的初始化
public class Singleton {
private static class SingletonHolder {
private static final Singleton INSTANCE = new Singleton();
}
private Singleton (){}
public static final Singleton getInstance() {
return SingletonHolder.INSTANCE;
}
} 4.通过枚举实现,枚举实例的创建时线程安全的,并且对序列化有保证
public enum Singleton {
INSTANCE;
public void whateverMethod() {
}
}
本文详细介绍了单例模式的四种实现方式:懒汉式、饿汉式、静态内部类及枚举方式。对比了不同实现方式在线程安全性与性能上的优劣。
833

被折叠的 条评论
为什么被折叠?



