码迷,mamicode.com
首页 > 其他好文 > 详细

使用ThreadLocal来实现一个本地缓存

时间:2018-08-27 18:33:18      阅读:457      评论:0      收藏:0      [点我收藏+]

标签:方案   查询   div   线程   key   this   value   响应   结束   

大家应该知道,用户从发起请求,到服务器响应的这个过程中,在服务器中是在一个线程中的。如果我们吧查询出来的对象放到这个线程自己的缓存中,到用户请求结束时,把这些东西清理掉,应该是一个不错的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来实现一个本地缓存

标签:方案   查询   div   线程   key   this   value   响应   结束   

原文地址:https://www.cnblogs.com/frankyou/p/9542520.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!