描述ThreadLocal的底层实现原理及常用场景

实现原理:

  • 每个Thread线程内部都有一个ThreadLocalMap;以线程作为key,泛型作为value,可以理解为线程级别的缓存。每个线程都会获得一个单独的map。
  • 提供了set和get等访问方法,这些方法为每个使用该变量的线程都存有一份独立的副本,因此get方法总是返回由当前线程在调用set时设置的最新值。

应用场景:

  • JDBC连接
  • Session管理
  • Spring事务管理
  • 调用链,参数传递
  • AOP

ThredLocal是一个解决线程并发问题的类,用于创建线程本地变量,我们知道一个对象的所用线程会共享它的全局变量,所以这些变量不是线程安全的,我们可以使用同步技术。但是当我们不想使用同步的时候,我们可以选择ThreadLocal变量。例如,用于JDBC的连接对象不是线程安全的,因此,当多线程应用程序在没有协同的情况下,使用全局变量时,就不是线程安全的。通过将JDBC的连接对象保存到ThreadLocal中,每个线程都会拥有属于自己的连接对象副本。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值