博客
关于我
ThreadLocal
阅读量:306 次
发布时间:2019-03-03

本文共 1243 字,大约阅读时间需要 4 分钟。

ThreadLocal详解

基本使用

ThreadLocal是一种轻量级的线程存储机制,允许每个线程维护自己的独立数据副本。通过ThreadLocal,开发者可以在多线程环境中安全地存储和获取线程局部变量。

示例代码
public class TestThreadLocal {    static ThreadLocal
THREADLOCAL = new ThreadLocal<>(); public static void main(String[] args) throws InterruptedException { Thread t1 = new Thread(new Runnable() { @Override public void run() { THREADLOCAL.set(0); System.out.println("0号线程: " + THREADLOCAL.get()); } }); Thread t2 = new Thread(new Runnable() { @Override public void run() { System.out.println("1号线程: " + THREADLOCAL.get()); } }); t1.start(); t1.join(); t2.start(); }}

工作原理

ThreadLocal通过ThreadLocalMap实现线程内存存储。每个线程都有自己的ThreadLocalMap,存储ThreadLocal键和对应的值。ThreadLocalMap采用哈希表结构,通过弱引用管理键,以防止内存泄漏。

ThreadLocalMap内部结构
  • Entry类:继承自WeakReference,存储ThreadLocal键和值。
  • set方法:将值存储到当前线程的ThreadLocalMap中。
  • 查找和替换机制:通过键的哈希码确定数组位置,逐个查找冲突项,必要时重新组织存储位置。
  • 应用场景

  • 参数传递
    • 在web应用中,统一处理请求参数并存储到ThreadLocal,供后续业务逻辑使用。
  • 数据共享
    • 在多线程任务中,需要在不同线程间安全共享数据,避免数据竞争和干扰。
  • 注意事项

  • 清理机制
    • 避免线程复用时的数据错乱,及时清理ThreadLocal引用。
  • 内存管理
    • ThreadLocalMap中的值是强引用,需谨慎处理,避免内存泄漏。
  • 通过ThreadLocal,开发者可以在多线程环境中高效管理线程局部数据,提升应用的安全性和性能。

    转载地址:http://slxm.baihongyu.com/

    你可能感兴趣的文章
    Nacos服务注册与发现demo
    查看>>
    nacos服务注册流程
    查看>>
    nacos本地可以,上服务器报错
    查看>>
    Nacos注册中心有几种调用方式?
    查看>>
    nacos注册失败,Feign调用失败,feign无法注入成我们的bean对象
    查看>>
    nacos源码 nacos注册中心1.4.x 源码 nacos源码如何下载 nacos 客户端源码下载地址 nacos discovery下载地址(一)
    查看>>
    Nacos简介、下载与配置持久化到Mysql
    查看>>
    Nacos简介和控制台服务安装
    查看>>
    Nacos管理界面详细介绍
    查看>>
    Nacos编译报错NacosException: endpoint is blank
    查看>>
    nacos自动刷新配置
    查看>>
    Nacos部署中的一些常见问题汇总
    查看>>
    NACOS部署,微服务框架之NACOS-单机、集群方式部署
    查看>>
    Nacos配置Mysql数据库
    查看>>
    Nacos配置中心中配置文件的创建、微服务读取nacos配置中心
    查看>>
    Nacos配置中心集群原理及源码分析
    查看>>
    nacos配置在代码中如何引用
    查看>>
    nacos配置新增不成功
    查看>>
    nacos配置自动刷新源码解析
    查看>>
    Nacos集群搭建
    查看>>