java设计模式-单例模式
1.核心:保证一个类只有一个实例,并且提供一个访问该实例的全局访问点。
2.常见应用场景
1) windows底下的任务管理器。
2)windows底下的回收站。
3)springMVC的控制器对象也是单例。
4)网站计数器。
3.单例模式的优点
1)由于单例模式只生成一个实例,减少了系统的开销,当一个对象的产生需要比较多的资源时,如读取配置、产生其他依赖对象时,则可以通过在应用时直接产生一个单例对象,然后永久驻留内存的方式解决。
2)单例模式可以在系统设置全局的访问点,优化环共享资源访问,例如可以设计一个单例类,负责所有数据表的映射处理。
4.常见的五种单例模式实现方式
1)主要:饿汉式(线程安全,调用效率高。但是不能延时加载)、懒汉式(线程安全,调用效率高,可以延时加载)
2)其他:双重检测锁定(由于JVM底层内部模型原因,偶尔会出问题。不建议使用)、静态内部类式(线程安全,调用效率高,可以延时加载)、枚举单例(线程安全,调用效率高,不能延时加载)
5.实例
/*
* 单例模式-饿汉式
*/
public class SingletonDemo01 {
// 类初始化时,立即加载这个对象(没有延时加载的优势),加载类时,天然的是线程安全的!
private static SingletonDemo01instance = new SingletonDemo01();
// 私有构造器
private SingletonDemo01() {
}
// 方法没有同步,调用效率高!
public static SingletonDemo01 newtstant() {
return instance;
}
}
/*
* 单例模式-懒汉式
*/
public class SingletonDemo02 {
// 类初始化时,不初始化这个对象(延时加载,真正用的时候再创建)
private static SingletonDemo02instance;
// 私有化构造器
private SingletonDemo02() {
}
// 方法同步,调用效率低
public synchronizedstatic SingletonDemo02 getInstance() {
if (instance ==null) {
instance = new SingletonDemo02();
}
return instance;
}
}
/*
* 单例模式-静态内部类
* 优势:1.外部类没有static属性,则不会像饿汉式那样立即加载对象发(延时加载)。
* 2.只有真正调用getInstance方法,才会加载静态内部类。加载类时是线程安全的。instance
* 是static final类型,保证了内存中只有这样一个实例存在,而且只能被赋值一次,从而保
* 证了线程的安全性。
* 3.兼备了并发高效调用和延时加载的优势。
*/
public class SingletonDemo03 {
/*
* 静态内部类
*/
private staticclass SingletonClassInstance {
private staticfinal SingletonDemo03 instance = new SingletonDemo03();
}
/*
* 私有构造器
*/
private SingletonDemo03() {
}
public static SingletonDemo03 getInstance() {
return SingletonDemo03.SingletonClassInstance.instance;
}
}