博客
关于我
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中使用ribbon
    查看>>
    Nacos使用OpenFeign
    查看>>
    Nacos使用Ribbon
    查看>>
    Nacos做注册中心使用
    查看>>
    Nacos做配置中心使用
    查看>>
    Nacos入门过程的坑--获取不到配置的值
    查看>>
    Nacos原理
    查看>>
    Nacos发布0.5.0版本,轻松玩转动态 DNS 服务
    查看>>
    Nacos启动异常
    查看>>
    Nacos命名空间配置_每个人用各自自己的命名空间---SpringCloud Alibaba_若依微服务框架改造---工作笔记001
    查看>>
    Nacos和Zookeeper对比
    查看>>
    Nacos在双击startup.cmd启动时提示:Unable to start embedded Tomcat
    查看>>
    Nacos基础版 从入门到精通
    查看>>
    Nacos如何实现Raft算法与Raft协议原理详解
    查看>>
    Nacos安装教程(非常详细)从零基础入门到精通,看完这一篇就够了
    查看>>
    Nacos实战攻略:从入门到精通,全面掌握服务治理与配置管理!(上)
    查看>>
    Nacos实战攻略:从入门到精通,全面掌握服务治理与配置管理!(下)
    查看>>
    Nacos心跳机制实现快速上下线
    查看>>
    nacos报错com.alibaba.nacos.shaded.io.grpc.StatusRuntimeException: UNAVAILABLE: io exception
    查看>>
    nacos服务提供和发现及客户端负载均衡配置
    查看>>