介绍
单例模式是Java中的一种设计模式。一个类只有一个实例,且该类能自己创建这个实例,并且提供一个全局访问点的一种模式。这种模式属于创建型模式。
优点
- 单例模式保证只有一个实例,减少了内存的开销;
- 避免资源的多重占用;
- 提供全局访问点,方便共享资源的调用。
缺点
- 没有接口、不能继承,拓展困难。
使用场景
单例模式的特点是只有一个实例,一般用在需要频繁实例化的一些类、某些只要求一个实例对象、或一些系统级别的操作。
单例模式的两种实现方式
饿汉模式
线程安全,调用效率高。但是不能延时加载。基于classloader机制避免了多线程同步问题。同时类加载的时候就初始化了,浪费内存。
/**
* 单例模式
* 饿汉模式
*/
public class SingletonMode {
//饿汉模式 类初始化时就加载
private static final SingletonMode instance=new SingletonMode();
private SingletonMode(){
}
public static SingletonMode getInstance(){
return instance;
}
}
懒汉模式
第一次调用时初始化,避免内存浪费,线程不安全,如需要线程安全需要加锁。
/**
* 单例模式
* 懒汉模式-没加锁
*/
public class SingletonMode {
private static SingletonMode instance;
private SingletonMode(){
}
public static SingletonMode getInstance() {
if (instance==null){
instance=new SingletonMode();
}
return instance;
}
}
懒汉模式如果需要线程安全就要加锁synchronized
/**
* 单例模式
* 懒汉模式-加锁
*/
public class SingletonMode {
private static SingletonMode instance;
private SingletonMode(){
}
//但是为了防止对象多线程时重复创建对象,所以必须加synchronized,效率不高,因为多线程时需要等待
public static synchronized SingletonMode getInstance() {
if (instance==null){
instance=new SingletonMode();
}
return instance;
}
}
双重校验锁
/**
* 单例模式
* 懒汉模式-双重校验锁
*/
public class SingletonMode {
//volatile 禁止重排序
private volatile static SingletonMode instance;
private SingletonMode() {
}
public static SingletonMode getInstance() {
if (instance == null) {
synchronized (SingletonMode.class) {
if (instance == null) {
instance = new SingletonMode();
}
}
}
return instance;
}
}
写个博客记录下