ThreadLocal保存用户信息

本文探讨了如何利用com.kucai.blogparent.utils.UserThreadLocal类实现线程变量隔离,解释了为何不正确删除ThreadLocal可能导致内存泄露,并介绍了强引用和弱引用的概念。
摘要由CSDN通过智能技术生成
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一起被删掉,长久以往就会导致内存泄露

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值