博客
关于我
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执行计划 EXPLAIN参数
    查看>>
    MySQL执行计划【explain】,看这一篇就够啦!
    查看>>
    Mysql执行计划字段解释
    查看>>
    mysql执行计划怎么看
    查看>>
    MySQL执行计划解读
    查看>>
    mysql执行顺序与索引算法
    查看>>
    mysql批量update优化_Mysql中,21个写SQL的好习惯,你值得拥有呀
    查看>>
    mysql批量update操作时出现锁表
    查看>>
    MYSQL批量UPDATE的两种方式
    查看>>
    mysql批量修改字段名(列名)
    查看>>
    MySQL批量插入数据遇到错误1213的解决方法
    查看>>
    mysql技能梳理
    查看>>
    MySQL报Got an error reading communication packets错
    查看>>
    Mysql报错Can‘t create/write to file ‘/tmp/#sql_3a8_0.MYD‘ (Errcode: 28 - No space left on device)
    查看>>
    MySql报错Deadlock found when trying to get lock; try restarting transaction 的问题解决
    查看>>
    MySQL报错ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘
    查看>>
    Mysql报错Packet for query is too large问题解决
    查看>>
    mysql报错级别_更改MySQL日志错误级别记录非法登陆(Access denied)
    查看>>
    Mysql报错:too many connections
    查看>>
    MySQL报错:无法启动MySQL服务
    查看>>