ThreadLocal之我见
一直都对ThreadLocal类感觉隔层纱似的,因为在开发中几乎是没有用到过,也大体知道他是用来保存一个线程范围内有效的变量。甚至觉着它的实现就是类似于一个map,以线程id作为key,要保存的变量作为value。但当时看源代码,并不是自己想象的那样。由于几乎不用也一直没仔细看看源码。今天偶然的机会仔细的看了一下源代码,但它的关系结构跟自己想象的出入很大,这是我简单绘制的一个关系图:
简单描述下就是,Thread对象有一个指向ThreadLocalMap实例的threadLocals成员,ThreadLocalMap有一个Entry数组用来盛放数据,Entry的key是ThreadLocal实例,value就是本地线程变量。
其实说白了,不同线程的本地线程变量都是绑定在自己身上的,并没有统一放在一起。而ThreadLocal实例仅仅是作为entry的key。ThreadLocal实例是被多个线程共享作为entry的key的。用ThreadLocal作为entry的key确实让我感到莫名其妙,也一下子想不明白为何如此设计呢?
以下是我的个人见解:
第一,可以做到一个线程有多个threadlocal实例作为key,也就可以有多个本地线程变量了。如果以线程id为key的map形式保存本地线程变量就只能是一个了。
第二,本地线程变量都是私有携带在线程实例里边,仅仅是以线程共享的threadlocal实例作为key。所以访问、移除本地线程变量时,就不存在任何并发同步问题了。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?