Java ThreadLocal 解析

本文详细解析了线程局部存储(ThreadLocal)的概念、用途及其实现方式,阐述了其如何在多线程环境中提供线程级别的变量副本,减少线程安全问题,并分析了这种实现对性能的影响。同时,通过示例代码演示了如何重写 initialValue 方法以避免不必要的 set 调用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package concurrent;
/*
* @author: wjf
* @version: 2016年3月27日 下午2:44:46
*/

public class TestThreadLocal {
    /*
     * threadLocal 会为线程创建一个共享变量的本地副本,这样的话,可以在线程内部任意使用,而又不影响其他线程,这样一来就不会产生线程安全问题,
     * 也不会严重影响性能,但是有一点:使用 threadLocal 肯定需要耗费更大的内存
     */
    /*
     * threadLocal 重写 initialValue 方法,就可以不用调用 set() 方法,否则如果不调用 set 方法的话,initialValue
     * 方法默认返回 null
     */
    ThreadLocal<Long> locall=new ThreadLocal<Long>(){
        protected Long initialValue(){
            return Thread.currentThread().getId();
        }
    };
    ThreadLocal<String> locals=new ThreadLocal<String>(){
        protected String initialValue(){
            return Thread.currentThread().getName();
        }
    };
    public void set(){
        locall.set(Thread.currentThread().getId());
        locals.set(Thread.currentThread().getName());
    }
    public void get(){
        System.out.println(locall.get());
        System.out.println(locals.get());
    }
    public static void main(String[] args) throws InterruptedException {
        // TODO Auto-generated method stub
        final TestThreadLocal test=new TestThreadLocal();
//      test.set();
        test.get();
        Thread thread1=new Thread(){
            public void run(){
                test.set();
                test.get();
            }
        };
        thread1.start();
        thread1.join();
        test.get();


    }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值