Java线程安全的单例模式的几种实现

本文介绍了线程安全的单例模式实现方法,包括饿汉式、借助内部类、普通加锁及双重检测等四种常见方式,并探讨了每种方式的特点。

线程安全的单例模式实现有几种思路
1、饿汉式

2、借助内部类

3、普通加锁解决

4、双重检测,但要注意写法

如果单体模式继续扩展为N元单体模式,那就是对象池模式了

Java实现单例模式时,为了保证线程安全性,有多种常见的方法可以考虑: 1. **懒汉式 Singleton** (Double Checked Locking): 这种方式是在类加载时检查实例是否存在,如果没有,则创建并加锁。这是一种常用但不是最简洁的实现,因为每次请求都需要检查和同步。 ```java private volatile static MySingleton instance; public static MySingleton getInstance() { if (instance == null) { synchronized (MySingleton.class) { if (instance == null) { instance = new MySingleton(); } } } return instance; } ``` 2. **饿汉式 Singleton**: 类在加载时就初始化了单例实例,无需外部请求时再创建。这种方法一开始就持有实例,因此是线程安全的。 ```java private static final MySingleton instance = new MySingleton(); public static MySingleton getInstance() { return instance; } ``` 3. **静态内部类 Singleton** (也称为“线程本地 Singleton”): 利用了 `ThreadLocal` 或者匿名内部类来实现线程安全,每个线程都有自己的独立实例,这种方式避免了全局状态,提高了性能。 ```java private static class SingletonHolder { private static final MySingleton INSTANCE = new MySingleton(); } public static MySingleton getInstance() { return SingletonHolder.INSTANCE; } ``` 4. **枚举 Singleton**: 枚举是一种更为简单、直接的方式实现线程安全的单例,因为它本身就保证只有一个实例,并且是线程安全的。 ```java public enum MySingleton { INSTANCE; // ... 其他方法 } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值