package com.kucai.blogparent.utils;
/**
* 用于线程变量隔离的
*/
import com.kucai.blogparent.pojo.SysUser;
public class UserThreadLocal {
private UserThreadLocal(){};
private static final ThreadLocal<SysUser> LOCAL =new ThreadLocal<>();
public static void put(SysUser sysUser){
LOCAL.set(sysUser);
}
public static SysUser getUser(){
return LOCAL.get();
}
public static void remove(){
LOCAL.remove();
}
}
为什么不删除会有内存泄露风险
实现代表强应用,虚线代表弱应用
每个Thread维护一个ThreadLocalMap。key为使用弱应用的ThreadLoacl实例,value为线程变量的副本
强引用,使用最普通的引用,一个对象具有强引用,不会被垃圾回收器回收,当内存空间不足,java虚拟机宁愿抛出OutOfMemoryError错误,使程序异常终止,也不会回收这种对象如果想取消和某对象之间的联系,可以显示地将引用赋值为null,这可以使JVM在合适的时间就会回收改对象
弱引用,JVM进行垃圾回收时,无论内存是否充足,都会回收被弱引用关联的对象。在java中,用java.lang.WeakReference来表示
简单来说,如图key是弱引用,会因为垃圾回收机制删除,导致value无法被找到,而value是强引用,又不会随着key一起被删掉,长久以往就会导致内存泄露