ThreadLocal的原理和使用场景

每一个 Thread 对象均含有一个 ThreadLocalMap 类型的成员变量 threadLocals ,它存储本线程中所 =有ThreadLocal 对象及其对应的值 ThreadLocalMap 由一个个 Entry 对象构成 Entry 继承自 WeakReference<ThreadLocal<?>> ,一个 Entry 由 ThreadLocal 对象和 Object 构 成。由此可见, Entry 的 key 是 ThreadLocal 对象,并且是一个弱引用。当没指向 key 的强引用后,该 key就会被垃圾收集器回收 当执行set 方法时, ThreadLocal 首先会获取当前线程对象,然后获取当前线程的 ThreadLocalMap 对 象。再以当前ThreadLocal 对象为 key ,将值存储进 ThreadLocalMap 对象中。
get 方法执行过程类似。 ThreadLocal 首先会获取当前线程对象,然后获取当前线程的 ThreadLocalMap
对象。再以当前 ThreadLocal 对象为 key ,获取对应的 value 。
由于每一条线程均含有各自 私有的 ThreadLocalMap 容器,这些容器相互独立互不影响,因此不会存在
线程安全性问题,从而也无需使用同步机制来保证多条线程访问容器的互斥性。
使用场景:
1 、在进行对象跨层传递的时候,使用 ThreadLocal 可以避免多次传递,打破层次间的约束。
2 、线程间数据隔离
3 、进行事务操作,用于存储线程事务信息。
4 、数据库连接, Session 会话管理。
ThreadLocal 内存泄露原因,如何避免
内存泄露为程序在申请内存后,无法释放已申请的内存空间,一次内存泄露危害可以忽略,但内存泄露
堆积后果很严重,无论多少内存 , 迟早会被占光,
不再会被使用的对象或者变量占用的内存不能被回收,就是内存泄露。
强引用:使用最普遍的引用 (new) ,一个对象具有强引用,不会被垃圾回收器回收。当内存空间不足,
Java 虚拟机宁愿抛出 OutOfMemoryError 错误,使程序异常终止,也不回收这种对象。
Spring 框架在事务开始时会给当前线程绑定一个 Jdbc Connection, 在整个事务过程都是使用该线程绑定的
connection 来执行数据库操作,实现了事务的隔离性。 Spring 框架里面就是用的 ThreadLocal 来实现这种 隔离

相关推荐
小江的记录本4 分钟前
【Swagger】Swagger系统性知识体系全方位结构化总结
java·前端·后端·python·mysql·spring·docker
空太Jun5 分钟前
Spring Security 自定义数据库认证(初尝试)
java·数据库·spring
报错小能手5 分钟前
ios开发方向——swift内存基础
开发语言·ios·swift
minji...6 分钟前
Linux 多线程(四)线程等待,线程分离,线程管理,C++多线程,pthread库
linux·运维·开发语言·网络·c++·算法
麦德泽特8 分钟前
基于 Go 语言的 Modbus 项目实战:构建高性能、可扩展的工业通信服务器
服务器·开发语言·golang·modbus·rtu
sinat_2554878112 分钟前
泛型·学习笔记
java·jvm·数据库·windows·python
还是大剑师兰特13 分钟前
pnpm format 什么作用
开发语言·javascript·ecmascript
QuZero16 分钟前
Java Synchronized principle
java·开发语言
明灯伴古佛20 分钟前
面试:Java中乐观锁的实现原理是什么
java·面试·职场和发展
单片机学习之路23 分钟前
【Python】输入input函数
开发语言·python