单v纯微笑 2019-01-16 16:08 采纳率: 50%
浏览 3441
已采纳

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

刚看了一下ThreadLocal的源码,刚开始一直看不懂为什么ThreadLocalMap中要定义一个Entry。
最初的理解是只需要在ThreadLocalMap中定义一个Object类型的成员变量就可以了,直到看到网上看到有博主在手机上画的一幅草图才明白:


一个ThreadLocal对应一个线程,但是可没人说一个线程也只能有一个ThreadLocal。

发现ThreadLocalMap的作用是存放多个ThreadLocal和其对应的需要存储的值(this, value)。

问题是:

既然ThreadLocalMap 是每个线程一个,那么为什么不直接定义到Thread类中呢?反而要定义在ThreadLocal,然后还得交叉引用,这样并可读性非常糟糕,理解起来也不容易,那么设计者的考虑是什么呢?请大神指导!!

  • 写回答

2条回答 默认 最新

  • ZPengX 2019-05-16 22:06
    关注

    我也思考过这个问题,一直没找到相关文章,后来在stackoverflow上看到了一个回复,翻译过来分享一下。
    将ThreadLocalMap定义在Thread类内部看起来更符合逻辑,但是ThreadLocalMap并不需要Thread对象来操作,所以定义在Thread类内只会增加一些不必要的开销。定义在ThreadLocal类中的原因是ThreadLocal类负责ThreadLocalMap的创建,仅当线程中设置第一个ThreadLocal时,才为当前线程创建ThreadLocalMap,之后所有其他ThreadLocal变量将使用一个ThreadLocalMap。

    总的来说就是,ThreadLocalMap不是必需品,定义在Thread中增加了成本,定义在ThreadLocal中按需创建。

    这是本人的理解,如有错误,恳请指正!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 (希望可以解决问题)ma和mb文件无法正常打开,打开后是空白,但是有正常内存占用,但可以在打开Maya应用程序后打开场景ma和mb格式。
  • ¥20 ML307A在使用AT命令连接EMQX平台的MQTT时被拒绝
  • ¥20 腾讯企业邮箱邮件可以恢复么
  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?
  • ¥15 错误 LNK2001 无法解析的外部符号
  • ¥50 安装pyaudiokits失败
  • ¥15 计组这些题应该咋做呀
  • ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
  • ¥15 让node服务器有自动加载文件的功能
  • ¥15 jmeter脚本回放有的是对的有的是错的