ThreadLocal内存泄漏问题
- 每一个Thread维护一个ThreadLocalMap, key为使用弱引用的ThreadLocal实例,value为线程变量的副本(value也就是我们平时项目中存入的用户信息)
- 而我们的Thread属于强引用,ThreadLocal属于弱引用,在GC处理时ThreadLocal也就是我们的key被回收之后,只剩下value在内存中越堆越多可能会导致内存泄露
--------------强引用,使用最普遍的引用,一个对象具有强引用,不会被垃圾回收器回收。当内存空间不足,Java虚拟机宁愿抛出OutOfMemoryError错误,使程序异常终止,也不回收这种对象。
--------------弱引用,JVM进行垃圾回收时,无论内存是否充足,都会回收被弱引用关联的对象。在java中,用java.lang.ref.WeakReference类来表示。