首页 > 其他分享 >面经-并发-对ThreadLocal(线程隔离)的理解

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

时间:2022-08-24 23:55:33浏览次数:111  
标签:ThreadLocalMap 面经 ThreadLocal 线程 内存 key null

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无法回收。

 

标签:ThreadLocalMap,面经,ThreadLocal,线程,内存,key,null
From: https://www.cnblogs.com/lysboke/p/16622733.html

相关文章

  • 面经-HashTable与ConcurrentHashMap比较
    HashTable与ConcurrentHashMap比较1.HashTable与ConcurrentHashMap都是线程安全的Map集合。2.HashTable与ConcurrentHashMap的键和值都不能为空。3.HashTable并发度低,整......
  • 操作系统学习笔记5 | 用户级线程 && 内核级线程
    在上一部分中,我们了解到操作系统实现多进程图像需要组织、切换、考虑进程之间的影响,组织就是用PCB的队列实现,用到了一些简单的数据结构知识。而本部分重点就是进程之间的切......
  • 面经-wait与sleep的比较
    共同点:wait(),wait(long),sleep(long)的效果都是让当前线程暂时放弃CPU的使用权,进入阻塞状态。不同点:方法归属不同sleep(long)是Thread的静态方法。wait,wait(long)都......
  • 历时2月,动态线程池 DynamicTp 发布里程碑版本 V1.0.8
    关于DynamicTpDynamicTp是一个基于配置中心实现的轻量级动态线程池管理工具,主要功能可以总结为动态调参、通知报警、运行监控、三方包线程池管理等几大类。经过多个版......
  • ThreadLocal 分析
    1.先说说他的作用哦,提供线程内的局部变量,不同线程之间不会相互干扰,这种变量在线程的生命周期内起作用,减少同一个线程内多个函数或组件之间一些公共变量传递的复杂度。......
  • 面经-并发-线程状态
    java中的线程状态   线程状态_五种状态vs六种状态五种状态:操作系统层面分到CPU时间的:运行可以分到CPU时间的:就绪分不到CPU时间的:阻塞  Java中的Runnable......
  • 使用SpringBoot内置多线程
    SpringBoot使用多线程一概述1为什么使用多线程  在我们开发系统过程中,经常会处理一些好费时间的任务(如向数据库中插入上百万数据,将会导致系统阻塞),这个时候就会自然......
  • 线程池执行流程图
    publicThreadPoolExecutor(intcorePoolSize,intmaximumPoolSize,longkeepAliveTime,......
  • CountDownLatch demo演示数据分片多线程处理
    #CountDownLatchdemo演示数据分片多线程处理packagecom.example.core.mydemo;importorg.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;import......
  • java线程的学习
    1什么是线程进程是程序执行的一次过程,它是一个动态的概念,是系统资源分配的单位,通常一个进程中可以包含若干个线程,线程就是独立执行的路径。线程的执行存在优先权问题......