当前位置: 首页 > news >正文

要改进单例模式的实现以确保线程安全并优化性能,有几种常见的方法

要改进单例模式的实现以确保线程安全并优化性能,有几种常见的方法。以下是几种改进 `ThreadUtil` 单例实现的方法:

### 1. 懒汉式(线程安全版)
使用同步机制来确保线程安全,但只在第一次创建实例时同步,这样既保证了线程安全,又保持了懒加载的特点。

```java
public class ThreadUtil {
    private static ThreadUtil instance;
    private final ScheduledThreadPoolExecutor mThreadPoolExecutor;
    private final ExecutorService singleThreadExecutor;

    private ThreadUtil() {
        mThreadPoolExecutor = new ScheduledThreadPoolExecutor(CORE_POOL_SIZE);
        singleThreadExecutor = Executors.newSingleThreadExecutor();
    }

    public static synchronized ThreadUtil getInstance() {
        if (instance == null) {
            instance = new ThreadUtil();
        }
        return instance;
    }
}
```

### 2. 饿汉式
在类加载时就创建实例,避免了同步问题,但牺牲了懒加载。

```java
public class ThreadUtil {
    private static final ThreadUtil instance = new ThreadUtil();
    // ... 其他代码

    private ThreadUtil() {
        // ... 初始化代码
    }

    public static ThreadUtil getInstance() {
        return instance;
    }
}
```

### 3. 双重检查锁定(Double-Checked Locking)
使用双重检查锁定来实现延迟加载和线程安全。

```java
public class ThreadUtil {
    private static volatile ThreadUtil instance;
    private final ScheduledThreadPoolExecutor mThreadPoolExecutor;
    private final ExecutorService singleThreadExecutor;

    private ThreadUtil() {
        // ... 初始化代码
    }

    public static ThreadUtil getInstance() {
        if (instance == null) {
            synchronized (ThreadUtil.class) {
                if (instance == null) {
                    instance = new ThreadUtil();
                }
            }
        }
        return instance;
    }
}
```

### 4. 静态内部类
使用静态内部类的方式来实现单例,这种方式利用了类加载机制来保证初始化实例时的线程安全。

```java
public class ThreadUtil {
    private final ScheduledThreadPoolExecutor mThreadPoolExecutor;
    private final ExecutorService singleThreadExecutor;

    private ThreadUtil() {
        // ... 初始化代码
    }

    private static class Holder {
        private static final ThreadUtil INSTANCE = new ThreadUtil();
    }

    public static ThreadUtil getInstance() {
        return Holder.INSTANCE;
    }
}
```

### 5. 枚举
使用枚举来实现单例,这是最简单、最安全的实现方式。

```java
public enum ThreadUtil {
    INSTANCE;
    private final ScheduledThreadPoolExecutor mThreadPoolExecutor;
    private final ExecutorService singleThreadExecutor;

    ThreadUtil() {
        // ... 初始化代码
    }

    public ScheduledThreadPoolExecutor getThreadPoolExecutor() {
        return mThreadPoolExecutor;
    }

    public ExecutorService getSingleThreadExecutor() {
        return singleThreadExecutor;
    }
}
```

每种方法都有其优缺点,选择哪一种取决于具体的应用场景和需求。例如,如果单例的实例化成本很高,可能会倾向于使用懒汉式;如果对性能要求极高,可能会选择静态内部类或枚举方式。

http://www.lryc.cn/news/365918.html

相关文章:

  • k8s——Pod容器中的存储方式及PV、PVC
  • Java/Golang:活用interface,增加程序扩展性
  • SQL语句练习每日5题(四)
  • Java排序算法汇总篇,八种排序算法
  • R语言探索与分析20-北京市气温预测分析
  • 2024年安全现状报告
  • OV通配符ssl证书是什么
  • Selenium三种等待方式的使用!
  • websockets怎么工作的呢?
  • 栈 数组和链表实现
  • 如何备份和恢复华为手机?
  • 微波电路S参数测量实验方案
  • SpringTask Cron表达式
  • docker与docker-compose安装
  • 跨境反向海淘系统:业务流程解析与未来发展展望
  • Python语言字母:深度解析与魅力探索
  • 基于JSP技术的社区疫情防控管理信息系统
  • 区间预测 | Matlab实现QRBiTCN分位数回归双向时间卷积神经网络注意力机制时序区间预测
  • Spring MVC中,一个HTTP请求可能会被多个Handler处理
  • Vue3 时间格式化
  • SVN中trunk,branch,tag
  • React ahooks库和React Query库使用场景分析
  • 国产AI大模型哪家强?从投资者角度简单横评5款大模型!
  • uc/OS-III多任务程序
  • 6月13日在线研讨会 | 多产品多流程多团队的ALM选择方案
  • Maven使用${revision}实现多模块版本统一管理及注意事项
  • vue2 bug求助!!!(未解决,大概是浏览器缓存的问题或者是路由的问题)
  • C++的“引用”是条寄生虫
  • 人体感应提醒 大声公+微波模块
  • 正确的功能可将热晶体管风速计线性化