博客
关于我
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/

    你可能感兴趣的文章
    Mysql InnoDB存储引擎 —— 数据页
    查看>>
    Mysql InnoDB存储引擎中的checkpoint技术
    查看>>
    Mysql InnoDB存储引擎中缓冲池Buffer Pool、Redo Log、Bin Log、Undo Log、Channge Buffer
    查看>>
    MySQL InnoDB引擎的锁机制详解
    查看>>
    Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
    查看>>
    mysql InnoDB数据存储引擎 的B+树索引原理
    查看>>
    mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
    查看>>
    mysql problems
    查看>>
    MySQL replace函数替换字符串语句的用法(mysql字符串替换)
    查看>>
    mysql workbench6.3.5_MySQL Workbench
    查看>>
    MySQL Workbench安装教程以及菜单汉化
    查看>>
    MySQL Xtrabackup 安装、备份、恢复
    查看>>
    mysql [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
    查看>>
    MySQL _ MySQL常用操作
    查看>>
    MySQL – 导出数据成csv
    查看>>
    MySQL —— 在CentOS9下安装MySQL
    查看>>
    mysql 不区分大小写
    查看>>
    mysql 两列互转
    查看>>
    MySQL 中开启二进制日志(Binlog)
    查看>>
    MySQL 中文问题
    查看>>