单例模式(Singleton Pattern)是 Java 中最简单的设计模式之一。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。
在java虚拟机中只存在该类的一个实例对象。
注意:
- 1、单例类只能有一个实例。
- 2、单例类必须自己创建自己的唯一实例。
- 3、单例类必须给所有其他对象提供这一实例。
优点:
- 1、在内存里只有一个实例,减少了内存的开销,尤其是频繁的创建和销毁实例。
- 2、避免对资源的多重占用(比如写文件操作)。
缺点: 没有接口,不能继承,与单一职责原则冲突,一个类应该只关心内部逻辑,而不关心外面怎么样来实例化。
单例模式的几种实现方式
饿汉式、懒汉式、内部类懒汉式、枚举型
1.饿汉式
在该类初始化的时候创建,线程是安全的。没有枷锁,执行效率较高。但是占用内存,
public class Singleton {
private static Singleton instance = new Singleton();
private Singleton (){}
public static Singleton getInstance()
{
return instance;
}
}
2.懒汉式
需要考虑线程安全的问题,因为是在使用的时候才创建,有可能多个线程在同一时间同时调用创建实例的方法。不支持多线程
public class Singleton {
private static Singleton instance; private Singleton (){}
public static Singleton getInstance()
{ if (instance == null) {
instance = new Singleton();
}
return instance;
}
}
3.静态内部类懒汉式
这种方式具备很好的 lazy loading,能够在多线程中很好的工作,但是,效率很低,99% 情况下不需要同步
优点:第一次调用才初始化,避免内存浪费。
缺点:必须加锁 synchronized 才能保证单例,但加锁会影响效率。
4. 双重检查锁
这种方式采用双锁机制,安全且在多线程情况下能保持高性能。
5、登记式/静态内部类
能达到双检锁方式一样的功效,但实现更简单。对静态域使用延迟初始化,应使用这种方式而不是双检锁方式。这种方式只适用于静态域的情况,双检锁方式可在实例域需要延迟初始化时使用。