关于我们

质量为本、客户为根、勇于拼搏、务实创新

< 返回

ThreadLocal原理及内存泄漏原因

发布时间:2022-09-27 11:08:56

ThreadLocal有两个问题:

1. 每个变量副本是存储在哪了?

2. 变量副本是怎样从共享的变量中赋值出来的?源码中threadlocal的初始值是什么时候设置的。

ThreadLocal为每个线程维护一个变量的副本?

ThreadLocal原理及内存泄漏原因

每个线程的ThreadLocalMap都是线程自身持有的,但是初始化是在ThreadLocal中,然后每个线程相当于保存了一个map

这个map存的key是LocalThread的实例,value是存储的线程的局部变量

get方法

ThreadLocal原理及内存泄漏原因

根据当前线程获取Thread中的值

set方法

ThreadLocal原理及内存泄漏原因

根据当前线程获取当前线程的map,然后设置当前线程的值,

从而保证每个线程的值都是从自己的ThreadMap中获取

ThreadLocal为什么会引起内存泄漏

ThreadLocal原理及内存泄漏原因

ThreadLocal的弱引用作为key,如果gc想要回收的时候,ThreadLcoal必然回收,Thread ref -> Thread ->ThreadLocalMap->Entry->value这个强引用一直就会存在,造成内存泄漏

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持风纳云。

另外有需要云服务器可以了解下风纳云fengnayun.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


/template/Home/Dawn/PC/Static

选择风纳云,也许是您成就一番大事业的开端

注册账号