单例模式:保证同一个类只有一个对象实例;
主要复习三种实现方式:饿汉、饱汉、双重校验锁
1.饿汉 模式:
/**
* 单例模式之饿汉模式
* 类加载时即创建实例对象
*
*/
public class SingletonA {
private static SingletonA singleton = new SingletonA();
private SingletonA() {
}
public static SingletonA getInstance() {
return singleton;
}
}
2.饱汉模式:
/**
* 单例模式之饱汉模式
* 延迟加载,用的时候创建实例,存在线程安全问题:方法加上synchronized
*
*/
public class SingletonB {
private static SingletonB singleton;
private SingletonB() {
}
public static synchronized SingletonB getInstance() {
if (null == singleton) {
singleton = new SingletonB();
}
return singleton;
}
}
3.双重校验锁:

volatile作用:
1. 禁止指令重排序:上述代码中new Singleton()是一个非原子操作,编译器可能会重排序【构造函数可能在整个对象初始化完成前执行完毕,即赋值操作(只是在内存中开辟一片存储区域后直接返回内存的引用)在初始化对象前完成】。而线程B在线程A赋值完时判断instance就不为null了,此时B拿到的将是一个没有初始化完成的半成品。
2.保证可见性:线程A在自己的工作线程内创建了实例,但此时还未同步到主存中;此时线程B在主存中判断instance还是null,那么线程B又将在自己的工作线程中创建一个实例,这样就创建了多个实例。
volatile禁止指令重排序只能保证volatile修饰的代码之后的代码不会在它之前执行。

237

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



