保证该类只有一个对象,适用于对于配置文件的加载的情况。
分为饿汉单例和懒汉单例两种
//饿汉模式
class Singleton1{
private static Singleton1 singleton=new Singleton1();
private Singleton1(){};
public static Singleton1 getInstance(){
return singleton;
}
}
在加载类时就创建实例,故称为饿汉
//懒汉模式
class Singleton2{
private static Singleton2 single;
private Singleton2(){}
public static Singleton2 getInstance(){
if(single==null)
single=new Singleton2();
return single;
}
}
通过判断,看是否需要创建,偷懒称为懒汉
线程安全的懒汉单例(双重检查和锁)
修改创建的逻辑,其他不变
/*假设有ABC三个线程同时进入到这里,AB都经过第一个if判断,A先获得锁,然后创建,再轮到B
* 如果没有第二个if判断,那么B也会创建的对象,所以这里要有两个if判断
* C在第一个if就打回去
* */
public static SingleTest3 getInstance(){ //如果在方法前加锁,synchronzied,效率低,每次调用都会加锁
if(single==null){
synchronized (SingleTest3.class) { //在创建时再加锁,效率最高,同时避免线程安全问题
if(single==null){
single=new SingleTest3();
}
}
}
return single;
}
本文深入探讨了单例模式的两种实现方式:饿汉模式和懒汉模式,并详细解析了线程安全的懒汉单例模式的实现原理。
2490

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



