面试总结
1.说一下ThreadLocal
1.ThreadLocal是java中所提供的线程本地存储机制,可以利用该机制将数据缓存在某个线程内部,该线程在任意时刻,任意方法中获取缓存的数据
2.ThreadLocal底层是通过ThreadLocalMap来实现的,每个Thread对象(注意不是ThreadLocal对象)中都存在一个ThreadLocalMap,Map的key为ThreadLocal对象,Map的value为需要缓存的值
3.如果在线程池中使用ThreadLocal会造成内存泄漏,因为当ThreadLocal对象使用完之后,应该要把设置的key,value,也就是entry对象进行回收,但线程池中的线程不会回收,而线程对象是通过强引用指向ThreadLocalMap,ThreadLocalMap也是通过强引用指向Entry对象,线程不被回收,Entry对象也就不会被回收,从而出现内存泄漏,解决办法是,在使用了ThreadLocal对象之后,手动调用ThreadLocal的remove方法,手动清除Entry对象
4.ThreadLocal经典的应用场景就是连接管理(一个线程持有一个链接,该链接对象可以在不不同的方法之间进行传递,线程之间不共享同一个链接)
[]: https://www.bilibili.com/video/BV1mw411f719?p=4 “说一下ThreadLocal”
本文深入解析了Java中的ThreadLocal机制,它允许在不同方法间线程安全地存储数据。ThreadLocal通过ThreadLocalMap在每个线程内部维护数据,但在线程池中使用可能导致内存泄漏。解决这个问题的方法是在使用完ThreadLocal后调用remove方法。ThreadLocal的经典应用场景包括连接管理和线程间的独立状态管理。
92万+

被折叠的 条评论
为什么被折叠?



