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方法来清理线程当前线程的本地.
请注意,在此上下文中,您还需要考虑信息从一个请求泄漏到另一个请求的可能性.