Java中的ThreadLocal、ThreadLocalMap原理学习

本文详细探讨了Java中的ThreadLocal和ThreadLocalMap的工作原理。通过实例展示了ThreadLocal如何在不同线程间保持独立的变量副本,并解释了ThreadLocalMap内部结构,强调每个线程拥有自己的threadLocalMap,其key为ThreadLocal对象。同时,文章提到了线程局部变量可能导致的内存泄漏问题,建议在使用完ThreadLocal后调用remove方法以防止内存泄漏。
摘要由CSDN通过智能技术生成
public class ThreadLocalTest {
    public static void main(String[] args) {
        final ThreadLocal<Integer> local = new ThreadLocal<>();
        local.set(10);
        Thread t = new Thread(new Runnable() {
            @Override
            public void run() {
                System.out.println(Thread.currentThread().getName() + " local: " + local.get());
            }
        });
        t.start();
        System.out.println("Main local: " + local.get());
    }
}

输出结果:

Thread-0 local: null

Main local: 10

 

原因是在主线程中set了值,在子线程中没有set。threadLocal保存的是每个线程的值。

解析:

threadLocal类的set方法:

 

key为当前t

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值