概述
大家应该知道,用户从发起请求,到服务器响应的这个过程中,在服务器中是在一个线程中的。如果我们吧查询出来的对象放到这个线程自己的缓存中,到用户请求结束时,把这些东西清理掉,应该是一个不错的cache方案。
import java.util.HashMap; import java.util.Map; /** * ThreadLocalCache * */ public class ThreadLocalCache { /** * 实例字段,每个线程一个store,每个线程生产一个{@code ThreadLocalCache} INSTANCE */ private final ThreadLocal<Map<Object, Object>> store; public ThreadLocalCache() { this.store = new ThreadLocal<Map<Object, Object>>() { @Override protected Map<Object, Object> initialValue() { return new HashMap<Object, Object>(); } }; } public void put(Object key, Object value) { store.get().put(key, value); } public Object get(Object key) { return store.get().get(key); } }
最后
以上就是执着心锁为你收集整理的使用ThreadLocal来实现一个本地缓存的全部内容,希望文章能够帮你解决使用ThreadLocal来实现一个本地缓存所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复