核心作用
- 保证一个类只有一个实例,并且提供一个访问该实例的全局访问点
单例模式的优点
- 由于单例模式只生成一个实例,减少了系统性能开销,当一个对象的产生需要比较多的资源时,如读取配置、产生其他依赖对象时,则可以通过在引用启动时直接产生一个单例对象,然后永久驻留内存的方式来解决
- 单例模式可以在系统设置全局的访问点,优化环境共享资源访问,例如可以设计一个单例类,负责所有的数据表的映射处理
常见的五种单例模式实现方式
- 主要:
- 饿汉式(线程安全,调用效率高。但是,不能延时加载)
- 懒汉式(线程安全,调用效率不高。但是,可以延时加载)
- 其他:
- 双中检测锁式(由于JVM底层内部模型原因,偶尔会出问题[1])
- 静态内部类(线程安全,调用效率高,可以延时加载)
- 枚举单例(线程安全,调用效率高,不能延时加载)
实例
- 饿汉式
/**
* 测试饿汉式
* @author admin
*
*/
public class SingletonPattern01 {
private static SingletonPattern01 st=new SingletonPattern01();
private SingletonPattern01(){//构造器私有化
}
public static SingletonPattern01 getInstance(){
return st;
}
}
问题:如果只是加载本类,而不是调用getInstance(),甚至永远不会调用,则会造成资源浪费。
- 懒汉式
/**
* 懒汉式
* @author admin
*
*/
public class SingletonPattern02 {
private static SingletonPattern02 st2;
private SingletonPattern02(){
}
public static synchronized SingletonPattern02 getInstance(){
if(st2==null){
return st2=new SingletonPattern02();
}
return st2;
}
}
资源利用率高了。但是每次调用getInstance()方法都要同步,并发效率低。
-
更新时间2018/8/5 ↩
网友评论