抖音集团基于 Apache Doris 的实时数据仓库实践

阅读 27

2024-06-30

ThreadLocal原理
1ThreadLocal是一个工具类,为每个线程提供自己专属的本地变量
2ThreadLocal底层是通过ThreadLocalMap实现的,每个Thread对象中存在一个ThreadLocalMap,Map的key为ThreadLocal对象,Map的value为要缓存的值

ThreadLocal内存泄露问题是怎么产生的?
ThreadLocalMap 中使用的 key 为 ThreadLocal 的弱引用,而 value 是强引用。,在垃圾回收的时候,key 会被清理掉,而 value 不会被清理掉。假如我们不做任何措施的话,value 永远无法被 GC 回收,这个时候就可能会产生内存泄露。使用完 ThreadLocal方法后最好手动调用remove()方法(清除ThreadLocalMap中的带有key为该ThreadLocal对象的Entry)。

ThreadLocal的应用场景
当一个共享变量是共享的,但是需要每个线程互不影响,相互隔离,就可以使用ThreadLocal

精彩评论(0)

0 0 举报