ThreadLocal的原理

ThreadLocal原理

1ThreadLocal是一个工具类,为每个线程提供自己专属的本地变量

2ThreadLocal底层是通过ThreadLocalMap实现的,每个Thread对象中存在一个ThreadLocalMap,Map的key为ThreadLocal对象 ,Map的value为要缓存的值

ThreadLocal内存泄露问题是怎么产生的?

ThreadLocalMap 中使用的 key 为 ThreadLocal 的弱引用,而 value 是强引用。,在垃圾回收的时候,key 会被清理掉,而 value 不会被清理掉。假如我们不做任何措施的话,value 永远无法被 GC 回收,这个时候就可能会产生内存泄露。使用完 ThreadLocal方法后最好手动调用remove()方法(清除ThreadLocalMap中的带有key为该ThreadLocal对象的Entry)。

ThreadLocal的应用场景

当一个共享变量是共享的,但是需要每个线程互不影响,相互隔离,就可以使用ThreadLocal

相关推荐
OtIo TALL12 小时前
redis7 for windows的安装教程
java
uNke DEPH12 小时前
Spring Boot的项目结构
java·spring boot·后端
xixingzhe212 小时前
idea启动vue项目
java·vue.js·intellij-idea
wzl2026121313 小时前
企业微信定时群发技术实现与实操指南(原生接口+工具落地)
java·运维·前端·企业微信
凌波粒13 小时前
Java 8 “新”特性详解:Lambda、函数式接口、Stream、Optional 与方法引用
java·开发语言·idea
曹牧13 小时前
Eclipse:悬停提示(Hover)
java·ide·eclipse
oyzz12013 小时前
Spring EL 表达式的简单介绍和使用
java·后端·spring
iNgs IMAC14 小时前
Redis之Redis事务
java·数据库·redis
程序员小假14 小时前
向量检索的流程是怎样的?Embedding 和 Rerank 各自的作用?
java·后端
yaaakaaang14 小时前
二十二、模板方法模式
java·模板方法模式