ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
[彻底理解ThreadLocal(看这篇文章就够了)](https://zhuanlan.zhihu.com/p/61587053) [面试官:小伙子,听说你看过ThreadLocal源码?](https://www.cnblogs.com/wang-meng/p/12856648.html) 对于`ThreadLocal`,大家的第一反应可能是很简单呀,线程的变量副本,每个线程隔离。那这里有几个问题大家可以思考一下: * **ThreadLocal**的key是**弱引用**,那么在 threadLocal.get()的时候,发生**GC之后**,key是否**为null**? * **ThreadLocal**中**ThreadLocalMap**的**数据结构**? * **ThreadLocalMap**的**Hash算法**? * **ThreadLocalMap**中**Hash冲突**如何解决? * **ThreadLocalMap**扩容机制? * **ThreadLocalMap**中过期key的清理机制?**探测式清理**和**启发式清理**流程? * **ThreadLocalMap.set()**方法实现原理? * **ThreadLocalMap.get()**方法实现原理? * 项目中**ThreadLocal**使用情况?遇到的坑? * …… 上述的一些问题你是否都已经掌握的很清楚了呢?本文将围绕这些问题使用图文方式来剖析`ThreadLocal`的**点点滴滴**。 **全文目录** 1. **ThreadLocal**代码演示 2. **ThreadLocal**的数据结构 3. GC 之后key**是否为null**?