Theadlocal和它造成的内存泄露

ThreadLocal机制确保了线程安全,但可能导致内存泄露。每个线程都有一个TheadMap存储Theadlocal对象及其值,TheadMap使用弱引用作为key。若线程未结束且未调用remove,可能导致内存溢出。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Theadlocal和它造成的内存泄露

ThreadLocal、Thead、TheadMap。

Thead类里有一个成员变量是TheadMap类型,这个TheadMap类的每一个entry的key是Theadlocal类,value就是Theadlocal类中存储的对象。对Theadlocal进行get和set时都是通过当前线程获取TheadMap对象,然后以当前Theadlocal对象为key,要存的值为value存入其中。(一个线程可以创建很多个Theadlocal对象,相当于这个TheadMap对象中可以有很多对值)

ThreadLocal中存入的内容是线程私有的,是线程安全的。(如果存入对象的话一定要存入对象的副本,否则也是线程不安全的)。

保证new出来的Theadlocal不同:

主要是通过Theadlocal内封装的一个final int字段threadLocalHashCode,当每次new一个Theadlocal时,都会以相同的增加量原子更新一个AtomicInteger字段,然后把这个字段赋值给threadLocalHashCode,这个AtomicInteger字段是static的,也就是说下一次new Theadlocal时就还会在此基础上赋值给threadLocalHashCode一个新值。

内存泄露问题:TheadMap使用ThreadLocal的弱引用为key,当外界没有对TheadLocal的强引用时,内存就会回收TheadLocal。此时TheadMap的key就是null,但是TheadMap不会被回收,因为有当前线程对象Thread强关联。这样如果线程不结束就有可能造成内存溢出。ThreadLocal类自身可以在getset时遇见为null的key会清除掉,但是这样还不能避免内存溢出,需要调用者手动调用remove方法,手动删除不需要的ThreadLocal。建议把ThreadLocal设置为静态类变量,这样它的生命周期就会很长不会出现被回收的现象,用完再remove掉。

转载于:https://www.cnblogs.com/shizhuoping/p/11556770.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值