本文主要是介绍通过ThreadLocal实现单例模式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
最新学到一种新的实现单例的方式
import java.util.HashMap;
import java.util.Map;
public class AppContext {private static final ThreadLocal<AppContext> local = new ThreadLocal<>();private Map<String,Object> data = new HashMap<>();public Map<String, Object> getData() {return getAppContext().data;}//批量存数据public void setData(Map<String, Object> data) {getAppContext().data.putAll(data);}//存数据public void set(String key, String value) {getAppContext().data.put(key,value);}//取数据public void get(String key) {getAppContext().data.get(key);}//初始化的实现方法private static AppContext init(){AppContext context = new AppContext();local.set(context);return context;}//做延迟初始化public static AppContext getAppContext(){AppContext context = local.get();if (null == context) {context = init();}return context;}//删除实例public static void remove() {local.remove();}
}在这里插入代码片
上面的代码实现实际上就是懒汉式初始化的扩展,只不过用 ThreadLocal 替换静态对象来存储唯一对象实例。之所会选择 ThreadLocal,就是因为 ThreadLocal 相比传统的线程同步机制更有优势。
在传统的同步机制中,我们通常会通过对象的锁机制来保证同一时间只有一个线程访问单例类。这时该类是多个线程共享的,我们都知道使用同步机制时,什么时候对类进行读写、什么时候锁定和释放对象是有很烦琐要求的,这对于一般的程序员来说,设计和编写难度相对较大。
而 ThreadLocal 则会为每一个线程提供一个独立的对象副本,从而解决了多个线程对数据的访问冲突的问题。正因为每一个线程都拥有自己的对象副本,也就省去了线程之间的同步操作。
所以说,现在绝大多数单例模式的实现基本上都是采用的 ThreadLocal 这一种实现方式。
这篇关于通过ThreadLocal实现单例模式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!