ThreadLocalMap为什么要定义在ThreadLocal中,而不直接定义在Thread中?

本文深入探讨了Java中ThreadLocalMap的设计理念,解释了为何将其定义在ThreadLocal而非Thread类中,以及这种设计如何实现资源的有效利用和按需创建。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

刚看了一下ThreadLocal的源码,刚开始一直看不懂为什么ThreadLocalMap中要定义一个Entry。
最初的理解是只需要在ThreadLocalMap中定义一个Object类型的成员变量就可以了,直到看到网上看到有博主在手机上画的一幅草图才明白:
一个ThreadLocal对应一个线程,但是可没人说一个线程也只能有一个ThreadLocal。
发现ThreadLocalMap的作用是存放多个ThreadLocal和其对应的需要存储的值(this, value)。
问题是:
解释:
既然ThreadLocalMap 是每个线程一个,那么为什么不直接定义到Thread类中呢?反而要定义在ThreadLocal,然后还得交叉引用,这样并可读性非常糟糕,理解起来也不容易,那么设计者的考虑是什么呢?请大神指导!!
我也思考过这个问题,一直没找到相关文章,后来在stackoverflow上看到了一个回复,翻译过来分享一下。
将ThreadLocalMap定义在Thread类内部看起来更符合逻辑,但是ThreadLocalMap并不需要Thread对象来操作,所以定义在Thread类内只会增加一些不必要的开销。定义在ThreadLocal类中的原因是ThreadLocal类负责ThreadLocalMap的创建,仅当线程中设置第一个ThreadLocal时,才为当前线程创建ThreadLocalMap,之后所有其他ThreadLocal变量将使用一个ThreadLocalMap。
总的来说就是,ThreadLocalMap不是必需品,定义在Thread中增加了成本,定义在ThreadLocal中按需创建。
这是本人的理解,如有错误,恳请指正!
源问答地址:
https://ask.youkuaiyun.com/questions/730831

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值