对Java现有二十三种设计模式之一的单例模式的一种实现思路
私有的构造方法
私有的单实例对象引用
公有的供外部访问单实例的方法
使用双重锁检查机制,提高安全性,且降低了锁力度不太耗费性能,只在初次创建对象时加锁
单实例样例
public class SingletionDemo {
private static volatile SingletionDemo st;
private SingletionDemo() {
}
public static SingletionDemo getInstance() {
if (st == null) {
synchronized (SingletionDemo.class) {
if (st == null) {
st = new SingletionDemo();
}
}
}
return st;
}
}
volatile关键字的说明
可见性 可见性与JVM内存模型有关,非可见性的变量需线程通过主内存来Save和Load 有延迟
多线程可见,某线程对变量的修改立刻更新到其他线程。
可见性,并非意味着线程安全,因为多个线程仍就可以对同一个变量修改,只是立即可见,这意味这变量可能会直接从状态1跳到状态3,对于想要依次使用变量每个状态的线程而言就少了一个状态2,要想保证线程安全还得加锁,即synchronized ,当然这仍然只是个相对的线程安全,要想做到绝对的线程安全是异常困难的,就像做到绝对的公平一样。
有序性
不保证有序性指JVM存在机器级(编译时、汇编语言级)的指令优化,但当多个线程对同一个变量的状态依赖时就不能保证符合逻辑
禁止重排序,即先发生对变量的写操作后发生对变量的读操作JVM,执行逻辑如instance = new Singleton()
1.给 instance 分配内存
2.调用 Singleton 的构造函数来初始化成员变量
3.将instance对象指向分配的内存空间(执行完这步 instance 就为非 null 了)。
但是在 JVM 的即时编译器中存在指令重排序的优化。也就是说上面的第二步和第三步的顺序是不能保证的,最终的执行顺序可能是 1-2-3 也可能是 1-3-2。