javadoc说:
“Each thread holds an implicit reference to its copy of a thread-local variable as long as the thread is alive and the ThreadLocal instance is accessible; after a thread goes away, all of its copies of thread-local instances are subject to garbage collection (unless other references to these copies exist).
如果你的应用程序或(如果你在谈论请求线程)容器使用线程池,这意味着线程不会死。如果需要,你需要自己处理线程局部。唯一干净的方法是调用ThreadLocal.remove()方法。
有两个原因,你可能想清除线程本地线程的线程池中的线程:
>以防止记忆(或假设资源)泄漏,或
>以防止意外的信息从一个请求泄漏到另一个通过线程本地的另一个请求。
线程本地内存泄漏通常不是有界线程池的主要问题,因为任何线程局部变量最终都可能被覆盖;即当线被重复使用时。但是,如果你犯了重复创建一个新的ThreadLocal实例的错误(而不是使用静态变量来保存单例实例),线程本地值将不会被覆盖,并将累积在每个线程的threadlocals映射。这可能导致严重的泄漏。
假设你正在谈论在webapp处理HTTP请求时创建/使用的线程局部变量,那么避免线程局部泄漏的一种方法是使用webapp的ServletContext注册ServletRequestListener,并实现监听器的requestDestroyed方法来清除线程当前线程的本地化。
请注意,在这种情况下,您还需要考虑信息从一个请求泄漏到另一个请求的可能性。