广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Java并发编程之ThreadLocal详解
  • 433
分享到

Java并发编程之ThreadLocal详解

2024-04-02 19:04:59 433人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

目录一、什么是ThreadLocal?二、ThreadLocal的使用场景三、如何使用ThreadLocal四、数据库连接时的使用五、ThreadLocal工作原理六、小结七、注意点

一、什么是ThreadLocal?

ThreadLocal叫做线程本地变量ThreadLocal中填充的变量属于当前线程,该变量对其他线程而言是隔离的。ThreadLocal为变量在每个线程中都创建了一个副本,则每个线程都可以访问自己内部的副本变量。

二、ThreadLocal的使用场景

1.当对象进行跨层传递的时候,使用ThreadLocal可以避免多层传递,打破层次间的约束。

2.线程间数据隔离。

3.进行事务操作,用于存储线程事务信息。

4.数据库连接,Session会话管理。

三、如何使用ThreadLocal

ThreadLocal的作用是每一个线程创建一个副本。

在这里插入图片描述

从以上实例中可以看出,每一个线程都有自己的local值,设置一个休眠时间就是为了另外一个线程也能够及时的读取当前的local值。

四、数据库连接时的使用

在这里插入图片描述

上面是一个数据库连接的管理类,使用数据库的时候首先就是建立数据库连接,然后用完之后进行关闭,这里存在一个问题:如果1个客户端频繁的使用数据库,那么就需要建立多次连接和关闭,这样服务器可能会吃不消,如果有一万个客户端,服务器的压力更大。
这个时候就可以使用ThreadLocal,他会在每个线程中对连接创建一个副本,且在线程内部任何地方都可以使用,线程之间互不影响,这样一来就不存在线程安全问题,也不会严重影响程序执行性能。

五、ThreadLocal工作原理

ThreadLocal中的主要方法:

在这里插入图片描述

set方法

在这里插入图片描述

首先获取到当前线程t,然后调用getMap获取ThreadLocalMap,如果map存在,则将当前线程对象作为key,要存储的对象作为value存到map中去,如果该map不存在,则初始化一个。
ThreadLocalMap

在这里插入图片描述

ThreadLocalMap就是ThreadLocal的一个静态内部类,里面定义了一个Entry来保存数据,而且还是继承的弱引用。在Entry内部使用了ThreadLocal作为key,使用我们设置的value作为value。
getMap方法:


ThreadLocalMap getMap(Thread t) {

   return t.threadLocals;

}

调用当前线程t,返回当前线程t中的成员变量threadLocalsthreadLocals就是ThreadLocalMap

get()方法

在这里插入图片描述

首先获取当前线程,然后调用getMap方法获取一个ThreadLocalMap,如果map不为null,那就使用当前线程作为ThreadLocalMapEntry的键,然后值就作为相应的值,如果没有就设置一个初始值。
设置初始值:

在这里插入图片描述

remove()方法

在这里插入图片描述

map中移除即可。

六、小结

1.每个Thread内部都维护着一个ThreadLocalMap的引用

2.ThreadLocalMap是ThreadLocal的内部类,用Entry来进行存储

3.ThreadLocal创建的副本是存储在自己的threadLocals中的,也就是自己的ThreadLocalMap

4.ThreadLocalMap的键值为ThreadLocal对象,而且可以有多个threadLocals变量,因此保存在map中。

5.在进行get之前,必须先set,否则会报空指针异常,当然也可以初始化一个,但是必须重写initialValue()方法。

6.ThreadLocal本身并不存储值,他只是作为一个key来让线程从ThreadLocalMap获取value。

七、注意点

在这里插入图片描述

1.Thread中有一个map,就是ThreadLocalMap

2.ThreadLocalMap的key是ThreadLocal,值是我们自己设定的。

3.ThreadLocal是一个弱引用,当为null时,会被当成垃圾回收。

4.如果我们ThreadLocal是null了,也就是要被垃圾回收器回收了,但是此时我们的ThreadLocalMap生命周期和Thread的一样,他不会回收,这时候就出现一个现象,就是ThreadLocalMap的key没有了,但是value还在,这就造成了内存泄漏。解决办法:使用完ThreadLocal后,执行remove操作,避免出现内存溢出情况。

到此这篇关于Java并发编程之ThreadLocal详解的文章就介绍到这了,更多相关Java ThreadLocal内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Java并发编程之ThreadLocal详解

本文链接: https://www.lsjlt.com/news/127600.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Java并发编程之ThreadLocal详解
    目录一、什么是ThreadLocal?二、ThreadLocal的使用场景三、如何使用ThreadLocal四、数据库连接时的使用五、ThreadLocal工作原理六、小结七、注意点...
    99+
    2022-11-12
  • Java并发编程之threadLocal
    目录1、ThreadLocal介绍2、ThreadLocal使用实例3、ThreadLocal实现原理1、ThreadLocal介绍 多个线程访问同一个共享变量时特别容易出现并发问题...
    99+
    2022-11-12
  • 深入理解Java并发编程之ThreadLocal
    目录ThreadLocal简介ThreadLocal源码解析实现原理ThreadLocalMap源码分析InheritableThreadLocal参考资料ThreadLocal简介...
    99+
    2022-11-13
    Java ThreadLocal
  • Java 并发 - ThreadLocal详解
    ThreadLocal是通过线程隔离的方式防止任务在共享资源上产生冲突, 线程本地存储是一种自动化机制,可以为使用相同变量的每个不同线程都创建不同的存储。 @pdaiJava 并发 - ThreadLocal详解带着BAT大厂的面试问题去理...
    99+
    2022-12-02
    java框架 java全栈 java学习路线 java全栈知识 java面试 知识体系 java技术体系 java编程
  • Java并发编程之Executors类详解
    一、Executors的理解 Executors类属于java.util.concurrent包; 线程池的创建分为两种方式:ThreadPoolExecutor ...
    99+
    2022-11-12
  • Java并发编程之LockSupport类详解
    目录一、LockSupport类的属性二、LockSupport类的构造函数三、park(Object blocker)方法 和 park()方法分析四、parkNanos(Obje...
    99+
    2022-11-12
  • 详解Java高并发编程之AtomicReference
    目录一、AtomicReference 基本使用1.1、使用 synchronized 保证线程安全性二、了解 AtomicReference2.1、使用 AtomicReferen...
    99+
    2022-11-12
  • Java并发编程之详解ConcurrentHashMap类
    前言 由于Java程序员常用的HashMap的操作方法不是同步的,所以在多线程环境下会导致存取操作数据不一致的问题,Map接口的另一个实现类Hashtable 虽然是线程安全的,但是...
    99+
    2022-11-12
  • 详解Java并发编程之原子类
    目录原子数组AtomicIntegerArray原子更新器AtomicIntegerFieldUpdater原子累加器LongAdder原子数组 原子数组有AtomicInteger...
    99+
    2023-05-18
    Java并发原子类 Java并发
  • 详解Java并发编程基础之volatile
    目录一、volatile的定义和实现原理1、Java并发模型采用的方式2、volatile的定义3、volatile的底层实现原理二、volatile的内存语义1、volatile的...
    99+
    2022-11-12
  • Java并发编程之ConcurrentLinkedQueue源码详解
    目录一、ConcurrentLinkedQueue介绍二、构造方法三、入队 四、出队五、总结一、ConcurrentLinkedQueue介绍 并编程中,一般需要用到安全的...
    99+
    2022-11-12
  • Java并发编程之Exchanger方法详解
    简介 Exchanger是一个用于线程间数据交换的工具类,它提供一个公共点,在这个公共点,两个线程可以交换彼此的数据。 当一个线程调用exchange方法后将进入等待状态,直到另外一...
    99+
    2022-11-12
  • Java并发编程之详解CyclicBarrier线程同步
    CyclicBarrier线程同步 java.util.concurrent.CyclicBarrier提供了一种多线程彼此等待的同步机制,可以把它理解成一个障碍,所有先到达这个障碍...
    99+
    2022-11-12
  • 详解Java并发编程之volatile关键字
    目录1、volatile是什么?2、并发编程的三大特性3、什么是指令重排序?4、volatile有什么作用?5、volatile可以保证原子性?6、volatile 和 sy...
    99+
    2022-11-12
  • java并发编程详解
    一.synchronized的缺陷synchronized是java中的一个关键字,也就是说是Java语言内置的特性。那么为什么会出现Lock呢?如果一个代码块被synchronized修饰了,当一个线程获取了对应的锁,并执行该代码块时,其...
    99+
    2016-07-17
    java
  • Golang并发编程之Channel详解
    目录0. 简介1. channel数据结构2. channel创建3. 数据发送3.1 空通道的数据发送3.2 直接发送3.3 缓存区3.4 阻塞发送4. 接收数据4.1 空通道的数...
    99+
    2023-05-19
    Golang并发编程Channel Golang并发编程 Golang Channel
  • JUC并发编程之volatile详解
    目录   1. volatile 1.1 volatile关键字的作用 1.1.1 变量可见性 1.1.2 禁止指令重排序 1.2 volatile可见性案例 1.3 volatile非原子性案例 1.4 volatile 禁止重排序 1....
    99+
    2023-09-01
    java jvm 开发语言
  • 详解JUC并发编程之锁
    目录1、自旋锁和自适应锁2、轻量级锁和重量级锁轻量级锁加锁过程轻量级锁解锁过程3、偏向锁4、可重入锁和不可重入锁5、悲观锁和乐观锁6、公平锁和非公平锁7、共享锁和独占锁8、可中断锁和...
    99+
    2022-11-12
  • Java并发编程之阻塞队列(BlockingQueue)详解
    目录队列阻塞队列ArrayBlockingQueue重要属性构造方法添加元素add(e)offer(e)put(e)offer(e,time,unit)移除元素take()deque...
    99+
    2022-11-12
  • Java并发编程之显式锁机制详解
            我们之前介绍过synchronized关键字实现程序的原子性操作,它的内部也是一种加锁和解锁机制,是一种声明式的编程方式,我们只需要对方法或者代码块进行声...
    99+
    2023-05-30
    java 并发编程 显式锁机制
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作