ThreadLocal-线程级缓存实例

ThreadLocal-线程级缓存实例,第1张

ThreadLocal-线程级缓存实例

一,ThreadLocal理论:

理论自己写了一下,觉得写的稀烂,引用下吧:

引用自:https://www.jianshu.com/p/6fc3bba12f38

ThreadLocal 中 set 和 get *** 作的都是对应线程的 table数组,因此在不同的线程中访问同一个 ThreadLocal 对象的 set 和 get 进行存取数据是不会相互干扰的。

在每个线程Thread内部有一个ThreadLocal.ThreadLocalMap类型的成员变量threadLocals,这个threadLocals就是用来存储实际的变量副本的,键值为当前ThreadLocal变量,value为变量副本(即T类型的变量)。 初始时,在Thread里面,threadLocals为空,当通过ThreadLocal变量调用get()方法或者set()方法,就会对Thread类中的threadLocals进行初始化,并且以当前ThreadLocal变量为键值,以ThreadLocal要保存的副本变量为value,存到threadLocals。 然后在当前线程里面,如果要使用副本变量,就可以通过get方法在threadLocals里面查找。

    实际的通过ThreadLocal创建的副本是存储在每个线程自己的threadLocals中的;

    为何threadLocals的类型ThreadLocalMap的键值为ThreadLocal对象,因为每个线程中可有多个threadLocal变量,就像上面代码中的longLocal和stringLocal;

    在进行get之前,必须先set,否则会报空指针异常;如果想在get之前不需要调用set就能正常访问的话,必须重写initialValue()方法。 因为在上面的代码分析过程中,我们发现如果没有先set的话,即在map中查找不到对应的存储,则会通过调用setInitialValue方法返回i,而在setInitialValue方法中,有一个语句是T value = initialValue(), 而默认情况下,initialValue方法返回的是null。

二,ThreadLocal写一个缓存工具类:

由于线程上下文数据仅供自己使用, *** 作时无需使用同步和锁定机制。

package com.example.core.comm;

import java.util.HashMap;
import java.util.Map;

public class CoeRuntimeContext {


    private static final ThreadLocal> runtimeDatas = new ThreadLocal();

    public CoeRuntimeContext(){}

    public static Map getRuntimeDatas() {
        Map datas = runtimeDatas.get();
        if (datas==null){
           runtimeDatas.set(new HashMap<>());
        }
       return datas;
    }

    public static Object getRuntimeDatas(String key) {
        return getRuntimeDatas().get(key);
    }

    public static void  setRuntimeDatas(String key,String value){
        getRuntimeDatas().put(key,value);
    }

    public static void  removeRuntimeDatas(String key){
        getRuntimeDatas().remove(key);
    }
    public static void  clearRuntimeDatas(String key){
        getRuntimeDatas().clear();
    }
}

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5716829.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-17
下一篇 2022-12-17

发表评论

登录后才能评论

评论列表(0条)

保存