1、单例设计模式的作用
单例模式主要是为了避免因为创建了多个实例造成资源的浪费,且多个实例由于多次调用容易导致结果出现错误,而使用单例模式能够保证整个应用中有且只有一个实例。从其名字中我们就可以看出所谓单例,就是单个实例也就是说它可以解决的问题是:可以保证一个类在内存中的对象的唯一性,在一些常用的工具类、线程池、缓存,数据库,账户登录系统、配置文件等程序中可能只允许我们创建一个对象,一方面如果创建多个对象可能引起程序的错误,另一方面创建多个对象也造成资源的浪费。
2、单例模式的思想简介
(1)私有化该类的构造函数
(2)通过new在本类中创建一个本类对象
(3)定义一个公有的方法,将在该类中所创建的对象返回
3、单例模式的推荐写法
单例模式的写法大的方面可以分为5种五种①饿汉式②双重校验锁③静态内部类④枚举。
1、饿汉式
public class SingleMode {
private static SingleMode instance = new SingleMode();
private SingleMode(){};
public static SingleMode getInstance() {
return instance;
}
}
优点:类加载的时候完成了实例化,线程安全。
缺点:可能没有用到这个示例,但是却加载了,造成内存的浪费(较小)。
2、双重校验锁
public class SingleMode {
private static SingleMode instance = null;
private SingleMode(){};
public static SingleMode getInstance() {
if (instance == null) {
synchronized (SingleMode.class) {
if (instance == null) {
instance = new SingleMode();
}
}
}
return instance;
}
}
Double-Check概念对于多线程开发者来说不会陌生,如代码中所示,我们进行了两次if (instance== null)检查,这样就可以保证线程安全了。这样,实例化代码只用执行一次,后面再次访问时,判断if (instance== null),直接return实例化对象。
3、内部类
public class SingleMode{
private SingleMode() {};
private static class SingleModeHolder {
private static SingleMode instance = new SingleMode();
}
public static SingleMode getInstance() {
return SingleModeHolder.instance;
}
}
访问方式
SingleMode instance = SingleMode.getInstance();
优点:避免了线程不安全,延迟加载,效率高。
4、枚举
public enum SingleModeEnum {
instance;
private SingleModeEnum() {}
public void method(){}
}
访问方式
SingleModeEnum.instance.method();
借助JDK1.5中添加的枚举来实现单例模式。不仅能避免多线程同步问题,而且还能防止反序列化重新创建新的对象。可能是因为枚举在JDK1.5中才添加,所以在实际项目开发中,很少见人这么写过,这种方式也是最好的一种方式,如果在开发中JDK满足要求的情况下建议使用这种方式。