ThreadLocal tl = new ThreadLocal<>();
在一个函数中创建局部变量tl后set值,其逻辑是以tl自身做为key存储到当前的线程中的
public void set(T value) {
//获取当前线程
Thread t = Thread.currentThread();
//getMap直接返回了当前线程t中的threadLocals属性,而这个属性是protected的,在其他包中获取不到
//getMap这个函数也是protected的
ThreadLocalMap map = getMap(t);
if (map != null)
//以自身作为key存储到map上面获取的map中
map.set(this, value);
else
createMap(t, value);
}
在这个函数执行完后,局部tl变量在没有其他引用的情况下被gc回收掉,这是我们就失去了tl这个key,而threadLocals这个属性之前我们说过,是以protected修饰的,不能拿出来便利获取到tl的value,即value在我们看来已经是不可达的了,如果不做额外处理的话,由于threadLocals保留着其引用,只要当前线程不停止,value就不会被gc回收,即内存泄漏。
使⽤完 ThreadLocal ⽅法后 最好⼿动调⽤ remove() ⽅法。