设计模式-创建型-单例模式

1.概念

该设计模式保证全局只有一个实例对象可以使用,并且自动实例化,向外部提供一个使用接口。

2.作用

保证某些对象在项目中只有一份。

3.应用场景

比如:

全局的计数器------web页面文章阅读计数

全局的资源共享------用户登录后各个页面之间共享用户信息

线程池、数据库连接池------线程和连接可以多个,池应该只有一个

4.特点

单例对象全局只有一份

5.类与对象关系

使用static修饰该单例对象,保证全局可访问

6.实现

单例模式有多种实现方式,根据其创建时机的不同,可以分为饿汉式与懒汉式

6.1饿汉式

饿汉式会在类加载时就完成对象的创建

java 复制代码
public class EagerSingleton {

  private static final EagerSingleton instance = new EagerSingleton();

  private EagerSingleton() {
    // 私有化构造函数
  }

  public static EagerSingleton getInstance() {
    return instance;
  }
}

6.2懒汉式

在真正要获取对象时才会创建对象,因为是调用方法时才创建对象,所以存在线程安全问题。

java 复制代码
public class LazySingleton {

  private static LazySingleton instance;

  private LazySingleton() {
    // 私有化构造函数
  }

  public static LazySingleton getInstance() {
    if (instance == null) {
      instance = new LazySingleton();
    }
    return instance;
  }
}

6.3双重检查锁

为了保证懒汉式的线程安全,我们可以在方法上添加同步锁.

java 复制代码
public class DoubleCheckedLockingSingleton {  
    private static volatile DoubleCheckedLockingSingleton instance;  
  
    private DoubleCheckedLockingSingleton() {  
        // 私有化构造函数  
    }  
  
    public synchronized static DoubleCheckedLockingSingleton getInstance() {  
        if (instance == null) {  
             instance = new DoubleCheckedLockingSingleton();  
            }  
        }  
        return instance;  
    }  
}

为了进一步缩小锁的粒度,提升效率,我们可以修改成以下形式,也叫双重检查锁

java 复制代码
public class DoubleCheckedLockingSingleton {  
    private static volatile DoubleCheckedLockingSingleton instance;  
  
    private DoubleCheckedLockingSingleton() {  
        // 私有化构造函数  
    }  
  
    public static DoubleCheckedLockingSingleton getInstance() {  
        if (instance == null) {  
            synchronized (DoubleCheckedLockingSingleton.class) {  
                if (instance == null) {  
                    instance = new DoubleCheckedLockingSingleton();  
                }  
            }  
        }  
        return instance;  
    }  
}
相关推荐
Java陈序员几秒前
再见 Navicat!一款开源的 Web 数据库管理工具!
java·react.js·docker
知其然亦知其所以然17 分钟前
RAG 结果太水?用 RRF + Reranker 重排,效果翻倍提升!
java·后端·llm
SimonKing18 分钟前
吊打面试官系列:Spring为什么不推荐使用字段依赖注入?
java·后端·架构
魔镜魔镜_谁是世界上最漂亮的小仙女25 分钟前
java-集合
java·后端·程序员
真实的菜27 分钟前
消息队列高级特性与原理:解锁分布式系统的底层逻辑
java
若水不如远方28 分钟前
java范型
java
凌辰揽月31 分钟前
Web后端基础(基础知识)
java·开发语言·前端·数据库·学习·算法
lifallen37 分钟前
深入浅出 Arrays.sort(DualPivotQuicksort):如何结合快排、归并、堆排序和插入排序
java·开发语言·数据结构·算法·排序算法
长安不见38 分钟前
背景知识: 理解LimitLatch背后的AQS
java
小吕学编程41 分钟前
策略模式实战:Spring中动态选择商品处理策略的实现
java·开发语言·设计模式