美文网首页
ThreadLocal源码解析

ThreadLocal源码解析

作者: JAY_DaYin | 来源:发表于2020-11-12 18:20 被阅读0次

一.ThreadLocal简介
ThreadLocal 提供了线程局部变量,提供的局部变量与其他的变量不同,每个线程都可以通过set与get方法来访问独立初始化变量副本。
ThreadLocal 可以理解为线程本地变量,如果定义了一个ThreadLocal对象, 每个线程中的ThreadLocal读写是线程隔离的,相互不影响,它提供了一种将可变数据通过每个线程有自己的独立副本从而实现线程封闭的机制

包路径:java.lang.ThreadLocal

image.png

二.ThreadLocal相关类

ThreadLocal中嵌套内部类ThreadLocalmap ,这个类本质上就是一个map,与HashMap之类的实现相似,依然是Key-Value的形式,其中一个内部类Entry ,其中key可以看做是ThreadLocal实例,但是其本质是持有ThreadLocal的实例弱引用对象

image.png

在ThreadLocalMap中并没有对于ThreadLocalMap的引用,而是ThreadLocalMap在Thread类中,每个线程都向ThreadLocal里面塞值的时候,其实都是向自己持有的ThreadLocalMap里面写入数据,读的时候同理,首先从自己线程中取出自己持有的ThreadLocalMap,然后再根据ThreadLocal引用作为key取出Value,ThreadLocal实现了变量的线程隔离

image.png

Thread 源码部分截图

UML类图

image.png image.png

ThreadLocal原理图

image.png

首先主线程定义的两个ThreadLocal变量 ,两个子线程 线程A和线程B
线程A和线程B 分别持有一个ThreadLocalMap 用于保存自己的副本,主线程的ThreadLocal中封装了set和get方法
在线程A和线程B中调用ThreadLocal的Set方法,会首先通过getMap(Thread.currentThread)获取到线程A或者线程B持有的ThreadLocalMap对象,在调用map.put方法,并将ThreadLocal作为key,将要存储的数据作为value 来存放
get和set原理是类似,先获取当前调用线程的ThreadLocalMap,在从map中获取value ,并将ThreadLocal作为key

三.ThreadLocalMap源码分析
在分析ThreadLocalMap 的同时,结合ThreadLocal的方法一起进行分析

       private static final int INITIAL_CAPACITY = 16;
        private ThreadLocal.ThreadLocalMap.Entry[] table;
        private int size;
        private int threshold;

        private void setThreshold(int var1) {
            this.threshold = var1 * 2 / 3;
        }

        private static int nextIndex(int var0, int var1) {
            return var0 + 1 < var1 ? var0 + 1 : 0;
        }

        private static int prevIndex(int var0, int var1) {
            return var0 - 1 >= 0 ? var0 - 1 : var1 - 1;
        }

存储数据结构 ---Entry 类 继承WeakReference

        /**
         * The entries in this hash map extend WeakReference, using
         * its main ref field as the key (which is always a
         * ThreadLocal object).  Note that null keys (i.e. entry.get()
         * == null) mean that the key is no longer referenced, so the
         * entry can be expunged from table.  Such entries are referred to
         * as "stale entries" in the code that follows.
         */
        static class Entry extends WeakReference<ThreadLocal<?>> {
            /** The value associated with this ThreadLocal. */
            Object value;

            Entry(ThreadLocal<?> k, Object v) {
                super(k);
                value = v;
            }
        }

Entry 继承WeakReference 使用弱引用,可以将ThreadLocal对象的生命周期和线程生命周期解绑 ,持有对ThreadLocal的弱引用,可以使得ThreadLocal在没有其他强引用的时候被GC回收掉,这样可以避免因为线程得不到摧毁 导致ThreadLocal对象无法被垃圾回收器回收

参考文档

ThreadLocal源码分析

相关文章

  • Netty 源码分析-目录

    Netty源码分析1 - Promise异步框架的设计Netty源码分析2 - ThreadLocal 源码解析N...

  • Netty源码分析3 - FastThreadLocal 框架的

    在 第二章 ThreadLocal源码解析 详细分析了jdk本身的ThreadLocal源码。本节来看一下nett...

  • ThreadLocal原理解析(2):ThreadLocalMa

    我的CSDN博客同步发布:ThreadLocal原理解析(2):ThreadLocalMap源码解析 转载请注明出...

  • ThreadLocal源码解析

    一、使用场景 ThreadLocal用于不同线程获取各自数据,同一个线程也可根据不同的threadlocal对象获...

  • ThreadLocal源码解析

    ThreadLocal 1. ThreadLocal 是什么? 源码中解释到 ThreadLocal 就用于存储数...

  • ThreadLocal源码解析

    引言 ThreadLocal,线程变量,线程可以将本次线程内经常使用的变量存储到ThreadLocal中,方便本次...

  • threadLocal源码解析

    简单记录一些看threadLocal时遇到比较有意思的点。 ThreadLocalMap ThreadLocal的...

  • ThreadLocal源码解析

    概述 ThreadLocal,即线程本地变量,它为每一个使用该变量的线程提供独立的变量副本,每一个线程都可以独立地...

  • ThreadLocal源码解析

    ThreadLocal源码阅读记录,如有不妥,欢迎指出,共同学习,谢谢! 一、简单使用 ThreadLocal可以...

  • ThreadLocal源码解析

    1.概述 多线程并发时用于存储当前线程的本地变量副本。 2. ThreadLocal解析 set:用于存储当前线程...

网友评论

      本文标题:ThreadLocal源码解析

      本文链接:https://www.haomeiwen.com/subject/rhipbktx.html