专栏首页琦小虾的BinaryJava并发技术总结之二——ThreadLocal

Java并发技术总结之二——ThreadLocal

接上篇《Java并发技术总结之一——Java线程池》

二. ThreadLocal

参考地址:《Java中的ThreadLocal详解》

ThreadLocal 用来保证规避多线程访问线程不安全的情况,每个线程访问自己的副本变量,这样就避免了对资源的抢占导致数据不一致的问题。

2.1 原理

线程 Thread 中用 ThreadLocalMap 类型的 threadLocals, inheritableThreadLocals 存储当前线程与子线程数据的副本变量。 ThreadLocal 是不支持继承的,子线程在 ThreadLocal 中无法获取到父线程的副本。所以为了访问父线程的变量,Thread 类提供了 inheritableThreadLocals 字段。创建线程时调用 init() 方法,会判断父线程,也就是当前线程的 inheritableThreadLocals 是否为 null。如果不为 null,就会将数据存入 inheritableThreadLocals 中,用来获取父线程的 ThreadLocal 值,创建子线程时,会将父线程的 inheritableThreadLocals 复制给子线程。由于 InheritableThreadLocal 类继承与 ThreadLocal,而且重写了 get, set 方法,所以此后对 ThreadLocalMap 的操作,都是对 inheritableThreadLocal 执行的。

2.2 内存泄漏问题

由于 ThreadLocalMap 的 Entry 中,Key 字段是继承于 WeakReference 的,属于弱引用,只要被 GC,就会被回收。而 Entry 的 Value 如果是强引用,那么触发的一次 GC 会将 Key 回收,而强引用的 Value 由于与 Thread 有联系,所以只要该线程不结束,该 Value 不会被 GC 回收,这样就造成了内存泄漏。 所以在实际使用完 ThreadLocalMap 后,要及时的调用 remove 方法。

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

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Java并发技术总结之四——CAS

    CAS (Compare And Swap),即比较并交换,是解决多线程并行情况下使用锁造成性能损耗的一种机制。在 JAVA 中,sun.misc.Unsafe...

    剑影啸清寒
  • Java并发技术总结之五——AQS

    AQS (AbustactQueuedSynchronizer) 是 Java 提供的底层同步工具类,主要思想是用一个 int 类型的变量表示同步状态,以及一个...

    剑影啸清寒
  • Java并发技术总结之一——Java线程池

    注:1, 2, 3 步骤在 ThreadPoolExecutor # execute(Runnable command) 方法中;

    剑影啸清寒
  • Java并发技术总结之六——Java锁分类

    《[死磕 java同步系列之ReentrantLock源码解析(一)——公平锁、非公平锁]》)

    剑影啸清寒
  • Java并发技术总结之三——线程状态

    线程有六种状态:NEW, RUNNABLE(RUNNING), WAITING, TIME_WAITING, BLOCKED, TERMINATED。

    剑影啸清寒
  • Java并发编程之美

    并发编程相比 Java 中其他知识点的学习门槛较高,从而导致很多人望而却步。但无论是职场面试,还是高并发/ 高流量系统的实现,却都离不开并发编程,于是能够真正掌...

    加多
  • Java Web技术经验总结(二)

    阿杜
  • FastThreadLocal 是什么鬼?吊打 ThreadLocal 的存在!!

    ThreadLocal 大家都知道是线程本地变量,今天栈长再介绍一个神器:FastThreadLocal,从字面上看就是:Fast + ThreadLocal,...

    Java技术栈
  • Java进阶(七)正确理解Thread Local的原理与适用场景

    Jason Guo
  • Java Web技术经验总结(十二)

    而我们遇到的问题是Dubbo框架在启动时引发的异常,查看Dubbo的源码可以发现,Dubbo 3.0之后改了策略,不允许bean的重复定义。这个问题是参考Dup...

    阿杜
  • Java常用并发容器总结(二)

    ConcurrentHashMap是一个高效并发的HashMap,它采用了减小锁粒度的手段,内部进一步细分成了若干个小的HashMap,称为Segment段。默...

    张申傲
  • Java多线程学习(五)线程间通信知识点补充

    我自己总结的Java学习的系统知识点以及面试问题,目前已经开源,会一直完善下去,欢迎建议和指导欢迎Star: https://github.com/Snailc...

    用户2164320
  • JVM技术总结之二——GC机制

    GC 的机制是什么?垃圾回收器的基本原理是什么?是否可以立即回收内存?怎么样主动的通知 JVM 进行垃圾回收?

    剑影啸清寒
  • ThreadLocal原理分析与使用场景

    ThreadLoal 变量,线程局部变量,同一个 ThreadLocal 所包含的对象,在不同的 Thread 中有不同的副本。这里有几点需要注意:

    用户1516716
  • 2019年蚂蚁金服、头条、拼多多的面试总结(干货献上)

    说起来开始进行面试是年前倒数第二周,上午9点,我还在去公司的公交上,突然收到蚂蚁的面试电话,其实算不上真正的面试。面试官只是和我聊了下他们在做的事情(主要是做双...

    欧阳愠斐
  • Spring中的Controller ,Service,Dao是不是线程安全的?

    Spring容器中的Bean是否线程安全,容器本身并没有提供Bean的线程安全策略,因此可以说Spring容器中的Bean本身不具备线程安全的特性,但是具体还是...

    好好学java
  • 数据结构技术知识总结之二——BTree

    B-Tree 是 2-3 树的一种变形,可以设置度数 M,每个节点上最多可以有 M 个值;根据硬盘读取时的预读原理,磁盘读取时每次从磁盘上预读 page 容量(...

    剑影啸清寒
  • ThreadLocal:Java中的影分身

    老套路,先列举下关于ThreadLocal常见的疑问,希望可以通过这篇学习笔记来解决这几个问题:

    阿杜
  • 基于AOP和HashMap原理学习,开发Mysql分库分表路由组件!

    单纯了! 以前我也一直想 Java 面试就好好面试呗,嘎哈么总考一些工作中也用不到的玩意,会用 Spring、MyBatis、Dubbo、MQ,把业务需求实现了...

    小傅哥

扫码关注云+社区

领取腾讯云代金券