ThreadLocal详解

1. ThreadLocal

  1. 定义:提供线程局部变量;一个线程局部变量在多个线程中,分别有独立的值(副本)。
  2. 特点:简单(开箱即用)、快速(无额外开销)、安全(线程安全)。
  3. 场景:多线程场景(资源持有、线程一致性、并发计算、线程安全等场景)。
  4. 实现原理:java中使用哈希表实现。
  5. 应用范围:几乎所有提供多线程特征的语言。

2. ThreadLocal API

  1. get方法:
public class ThreadLocalAPi1 {

    private static ThreadLocal<Long> threadLocal = new ThreadLocal<Long>() {

        /**
         * Note1:
         *  只有ThreadLocal.get()方法时, 且只有当前ThreadLocal中没有值的时候,
         * 才会触发initialValue().
         */
        @Override
        protected Long initialValue() {
            System.out.println("initial value...");
            return 100L;
        }
    };

    public static void main(String[] args) {
        System.out.println(threadLocal.get());
    }
}

  1. 其它API
    remove:移除当前线程中的数据。
    set:给当前线程设置值。

3. ThreadLocal 使用场景

  1. 线程资源持有:供线程的各个部分使用,全局获取,减少编程难度。
    在这里插入图片描述
  2. 线程资源一致性:帮助需要保持线程一致的资源(如数据库事务)维护一致性,降低编程难度。
    在这里插入图片描述
  3. 线程安全:帮助只考虑了单线程的程序库,无缝向多线程场景迁移。
    在这里插入图片描述
  4. 分布式计算:帮助分布式计算场景的各个线程累计局部计算结果。
    分布式计算

4. 涉及ThreadLocal的框架

  1. Quartz:

    1. SimpleSemaphore提供资源隔离。
    2. SimpleSemaphore中的lockOwners(ThreadLocal)为重度锁操作前置过滤。
  2. Mybaits:

    1. SqlSessionMaagger#localSqlSession:在一个事务中,要保证事务,就必须所有的jdbc操作是在同一个连接中。所有的线程的连接都存放在这个ThreadLocal中。
      在这里插入图片描述
  3. Spring分布式事务:TransactionContextHolder#currentTransactionContext就是使用ThreadLocal。
    在这里插入图片描述

5. ThreadLocal源码分析

  1. 使用的hash算法,hash因子为’ox61c88647’

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值