内存泄漏
想问一道题:ThreadLocal是如何导致内存泄漏的,看了好多文章,我的答案可能是:
首先内存泄漏:分配的内存无法给垃圾回收器正确的回收,程序占用额外内存,直到可能导致系统性能下降
ThreadLocal内存泄漏:1. Entry中的value被强引用着,无法被回收2. ThreadLocal应用被设置为null了,ThreadLocal实例被回收了,没人管它对应的Entry了;看了好多,我太笨了,求求大神解释一下,话说内存这莫脆弱嘛?
首先内存泄漏:分配的内存无法给垃圾回收器正确的回收,程序占用额外内存,直到可能导致系统性能下降
ThreadLocal内存泄漏:1. Entry中的value被强引用着,无法被回收2. ThreadLocal应用被设置为null了,ThreadLocal实例被回收了,没人管它对应的Entry了;看了好多,我太笨了,求求大神解释一下,话说内存这莫脆弱嘛?
全部评论
我是雷锋
还有还有,ThreadLocalMap中的key设置为弱应用的目的也是为了避免内存泄露的嘛?谢谢各位
现在的ThreadLocal应该只要你用完以后remove就不会泄露吧 ThreadLocalMap里的弱引用会在GC时回收的
网上好多胡扯的,挺不靠谱,我自己看源码,观点不一定对:TL里有个内部类ThreadLocalMap,Map里有个Entry数组,每个Thread都持有一个Map的引用,map持有entry数组的引用,Entry持有的是TL的弱引用,同时持有TL对应的value的引用。如果不是弱引用,相当于只要线程不消亡,TL始终被持有,从而不会被回收。如果是弱引用,就会存在这种情况:Entry还在,value还在,但是TL被回收了。TL被回收了实际上意味着value也不被需要了,因此会有expungeStaleEntry函数,将其value也赋成null,从而让value也能被回收。但这个函数是在某些操作后才会调用,且无法遍历整个entry数组,有些该被回收的value实际上有可能不会被清理,从而造成内存泄漏
threadlocal被回收了,但是current thread ref还存在 value值无法清除 导致内存泄漏
mark
弱引用只是一种优化机制,并没有解决内存泄漏,主要是防止外面的强引用在remove之前突然消失的一种优化机制,如果想彻底搞明白,我最新的文章,源码看过之后的理解
相关推荐