专栏首页InvQ的专栏一句话解释ThreadLocal类

一句话解释ThreadLocal类

一个Thread类,有一个treadlocals变量,类型为ThreadLocal.ThreadLocalMap 初始值为null,这个变量,属于该线程,这个map由ThreadLocal类维护。

    /* ThreadLocal values pertaining to this thread. This map is maintained
     * by the ThreadLocal class. */
    ThreadLocal.ThreadLocalMap threadLocals = null;

一旦,由 new ThreadLocal() 操作,,并set值,那么创建ThreadLocalMap。

    public void set(T value) {
        Thread t = Thread.currentThread();
        ThreadLocalMap map = getMap(t);
        if (map != null)
            map.set(this, value);
        else
            createMap(t, value);
    }
       void createMap(Thread t, T firstValue) {
        t.threadLocals = new ThreadLocalMap(this, firstValue);
    }

其中key等于,ThreadLocal对象,value=值。

     ThreadLocalMap(ThreadLocal<?> firstKey, Object firstValue) {
            table = new Entry[INITIAL_CAPACITY];
            int i = firstKey.threadLocalHashCode & (INITIAL_CAPACITY - 1);
            table[i] = new Entry(firstKey, firstValue);
            size = 1;
            setThreshold(INITIAL_CAPACITY);
        }

如果此线程再new一个ThreadLocal() ,再调用set方法,那么这个threadlocals变量会有两个值。 key为新建的ThreadLocal对象。 其实,一个线程,有一个共享变量,供多个threadlocals使用。

测试案例如下:

 ThreadLocal l1 = new ThreadLocal();
        ThreadLocal l2 = new ThreadLocal();
        l1.set("1");
        l2.set("2");
        System.out.println(l2.get());

附上实例:

public class ThreadLocalTest {
    int p = 1;

    public int getP() {
        return p;
    }

    public void setP(int p) {
        this.p = p;
    }

    public static void main(String[] args)  {

        ThreadLocalTest s1 = new ThreadLocalTest();
        System.out.println(s1);
        System.out.println("s1 p="+s1.getP());

        ThreadLocal<ThreadLocalTest> main = new ThreadLocal(){
            @Override
            protected Object initialValue() {
                return s1;
            }
        };
        ThreadLocalTest m =  main.get();
        m.setP(111);
        System.out.println(m);
        System.out.println("main线程 p="+m.getP());
        new Thread(()->{
            ThreadLocal<ThreadLocalTest> t = new ThreadLocal(){
                @Override
                protected Object initialValue() {
                    return s1;
                }
            };
            ThreadLocalTest t2 = t.get();
            t2.setP(222);
            System.out.println("子线程 p="+t2.getP());
            System.out.println(t2);
        }).start();
    }
}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Netty 的 FastThreadLocal VS JAVA ThreadLocal

    我们都有在源码中发现 FastThreadLocal 的身影,顾名思义,Netty 作为高性能的网络通信框架,FastThreadLocal 是比 JDK 自身...

    MickyInvQ
  • 模仿echo命令学习BIO——Java实现

    在程序的开发之中Java里面最小的处理单元就是线程,也就是说每一个线程可以进行IO的处理,在处理之中,该线程无法进行任何的其他操作。 . 多线程是不可能无限...

    MickyInvQ
  • ArrayList与Vector的区别

    ArrayList与Vector都是java的集合类,都是实现了List接口的实现类

    MickyInvQ
  • 【干货】基于注意力机制的seq2seq网络

    seq2seq seq2seq的用途有很多,比如机器翻译,写诗,作曲,看图写文字等等用途很广泛!该模型最早在2014年被Cho和Sutskever先后提出,前者...

    zenRRan
  • Activiti学习详解【面试+工作】

    一:Activiti第一天 1:工作流的概念 ? 说明: 1) 假设:这两张图就是XX兄弟的请假流程图 2) 图的组成部分: A. 人物:范XX 冯X刚 王X军...

    Java帮帮
  • Activiti7工作流引擎-Activiti入门体验

    在 eclipse 或 idea 中安装 activiti-designer 插件即可使用,画板中包括以下结点: Connection—连接 Event—事...

    cwl_java
  • Web-第三十天 Activiti工作流【悟空教程】

    工作流(Workflow),就是“业务过程的部分或整体在计算机应用环境下的自动化”,它主要解决的是“使在多个参与者之间按照某种预定义的规则传递文档、信息或任务的...

    Java帮帮
  • [Go]Go语言实战-jwt-go会把存储的数值型转成float64

    解析出来的时候 info["id"]断言的时候 , 应该用float64断言 , info["id"].(float64) 然后再去强转

    陶士涵
  • 如何使用 Debian backports 更新源

    Backport的含义是”向后移植”,就是将软件新版本的某些功能移植到旧版本上来,这就称为backport。

    Debian中国
  • Linux之tail命令

    AlicFeng

扫码关注云+社区

领取腾讯云代金券