面经-并发-对ThreadLocal(线程隔离)的理解

追求适度,才能走向成功;人在顶峰,迈步就是下坡;身在低谷,抬足既是登高;弦,绷得太紧会断;人,思虑过度会疯;水至清无鱼,人至真无友,山至高无树;适度,不是中庸,而是一种明智的生活态度。

导读:本篇文章讲解 面经-并发-对ThreadLocal(线程隔离)的理解,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

ThreadLocal作用:

1.线程隔离。线程间:ThreadLocal可实现资源对象的线程隔离,让每个线程各用各的资源对象,避免争用引发的线程安全问题。

2.资源共享。线程内:ThreadLocal同时实现了线程内的资源共享。

ThreadLocal原理:关联资源

每个线程中都有一个独立的ThreadLocalMap类型的成员变量,用来存储资源对象。

1.调用set方法,就以ThreadLocal自己作为key,资源对象当作value,放入当前线程的ThreadLocalMap集合中。

2.调用get方法,就是以ThreadLocal自己作为key,到当前线程中查找关联的资源值。

3.调用remove方法,就是以ThreadLocal自己作为key,移除当前线程中关联的资源值。

ThreadLocalMap:懒汉式,使用时才创建。

当每创建一个新的ThreadLocal对象,它就会为ThreadLocal分配一个hash值,一开始hash值是0,索引也是0;再创建一个ThreadLocal对象,它的hash值是0+一个大值,计算桶下标,放在对应位置。

扩容:元素个数超过容量的2/3时会扩容。容量翻倍,所有key重新计算索引。

索引冲突:线性探测法。从冲突位置开始找下一个空闲位置。

ThreadLocal_key内存释放时机

为什么ThreadLocalMap中的key(即ThreadLocal)要设计为弱引用?

一旦别的地方不再占用内存中的key,弱引用对象占用的内存就可以直接释放掉。

1.Thread可能需要长时间运行(如线程池中的线程),如果key不再继续使用,需要在内存不足时释放其占用的内存。

2.但GC仅仅能让key释放,后续还要根据key是否为null来进一步释放值的内存。释放时机:

1.获取key发现null key

2.set key时会使用启发式扫描,清除临近的null key,启发次数与元素个数、是否发现null key有关。

3.remove(推荐)。因为一般使用ThreadLocal时都把它作为静态变量,因此GC无法回收。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/128068.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!