ThreadLocal描述

ThreadLocal是Java中的一个类,用于在多线程环境下存储和获取线程相关的数据。每个ThreadLocal对象都可以维护一个线程本地的变量副本,这意味着每个线程都可以独立地改变自己的副本,而不会影响其他线程的副本。这种特性使得ThreadLocal非常适合在多线程环境下实现线程封闭(Thread confinement)的数据共享。

原理描述:

复制代码
每个Thread对象内部都有一个ThreadLocalMap类型的成员变量,用于存储ThreadLocal对象与其对应的值。
当调用ThreadLocal的set方法时,实际上是将ThreadLocal对象作为key,要存储的值作为value,存储到当前线程的ThreadLocalMap中。
当调用ThreadLocal的get方法时,实际上是从当前线程的ThreadLocalMap中根据ThreadLocal对象获取对应的值。

形象描述:

想象ThreadLocal就像是一个神奇的魔法口袋,每个线程都有自己独立的口袋,里面可以放自己的宝贝。当线程需要存储数据时,它把数据放进自己口袋里,其他线程看不到。当线程需要取数据时,它从自己的口袋里取出来,不受其他线程影响。就像每个人有自己的口袋,可以放自己的东西,不受其他人干扰一样。

相关推荐
大春儿的试验田10 分钟前
Parameter ‘XXX‘ not found. Available parameters are [list, param1]
java
我很好我还能学34 分钟前
【面试篇 9】c++生成可执行文件的四个步骤、悬挂指针、define和const区别、c++定义和声明、将引用作为返回值的好处、类的四个缺省函数
开发语言·c++
程序员JerrySUN1 小时前
[特殊字符] 深入理解 Linux 内核进程管理:架构、核心函数与调度机制
java·linux·架构
2302_809798321 小时前
【JavaWeb】Docker项目部署
java·运维·后端·青少年编程·docker·容器
蓝婷儿1 小时前
6个月Python学习计划 Day 16 - 面向对象编程(OOP)基础
开发语言·python·学习
渣渣盟1 小时前
基于Scala实现Flink的三种基本时间窗口操作
开发语言·flink·scala
网安INF1 小时前
CVE-2020-17519源码分析与漏洞复现(Flink 任意文件读取)
java·web安全·网络安全·flink·漏洞
一叶知秋哈1 小时前
Java应用Flink CDC监听MySQL数据变动内容输出到控制台
java·mysql·flink
jackson凌1 小时前
【Java学习笔记】SringBuffer类(重点)
java·笔记·学习
sclibingqing1 小时前
SpringBoot项目接口集中测试方法及实现
java·spring boot·后端