侧边栏壁纸
博主头像
Monkey部落博主等级

Monkey部落,分享技术、经验、遇到的问题及解决方法,欢迎大家互相讨论分享。

  • 累计撰写 59 篇文章
  • 累计创建 36 个标签
  • 累计收到 2 条评论

目 录CONTENT

文章目录

ThreadLocal的底层原理

Monkey部落
2024-04-08 / 0 评论 / 0 点赞 / 418 阅读 / 446 字

ThreadLocal的底层原理

  1. ThreadLocal是Java中所提供的线程本地存储机制,可以利用该机制的将数据缓存在某个线程内部,该线程在任意时刻、任意方法中获取缓存的数据。

  2. ThreadLocal底层是通过ThreadLocalMap来实现的,每个Thread对象(注意不是ThreadLocal对象)中都存在一个ThreadLocalMap,Map的key为ThreadLocal对象,Map的value为需要缓存的值。

    image-20240408145139965

  3. 如果在线程池中使用ThreadLocal会造车过内存泄漏,因为当ThreadLocal对象使用完之后,应该要把设置的key,value,也就是Entry对象进行回收,但是线程池中的线程不会回收,而线程对象是通过强引用指向ThreadLocalMap,ThreadLocalMap也是通过强引用指向Entry对象,线程不能回收,Entry对象也就不会回收,从而出现内存泄漏,解决办法是,在使用了ThreadLocal对象之后,手动调用ThreadLocal的remove方法,手动清除Entry对象。

  4. TheradLocal经典的应用场景就是连接管理(一个线程持有一个连接,该连接对象可以在不同的方法直接进行传递,线程之间不共享同一个连接)。

实践案例

使用dynamic-datasource进行多数据源切换时,在使用@DS注解时不会出现问题,因为AOP会在最终清除ThreadLocal中存储的当前数据源,但是使用DynamicDataSourceContextHolder内部方法进行push指定数据源时,需要在最后进行poll,内部调用的方法也是ThreadLocal的remove方法,不然会出现线程复用时数据源错误问题。

0

评论区