ThreadLocal相关面试

本文深入解析ThreadLocal机制,探讨其在高并发环境下确保线程安全的原理。通过实例演示ThreadLocal如何为每个线程提供独立的变量副本,避免共享变量带来的竞态条件。同时,文章还讨论了ThreadLocalMap的内部实现,以及如何有效解决潜在的内存泄漏问题。
摘要由CSDN通过智能技术生成

1.ThreadLocal是什么?

1.其实ThreadLocal跟Synchronized一样,都是一个为了解决变量变化问题,类似给变量加锁;
2.实际上使用了ThreadLocal,相当于对对本地线程中的变量或者变量对象的引用copy一份,这样就使得各个线程中
  的变量和对象互不影响;这样各个线程在高并发场景下,适合各个线程不共享变量值的操作;
3.ThreadLocal是无状态的,所谓的无状态主要是指的ThreadLocal中的变量都是相互隔离的,
  线程间变量变化是不影响其他线程中的变量值得

2.ThreadLocal的工作原理?

1.ThreadLocal中使用ThreadLocalMap去存储变量相关的数据
  其中ThreadLocal本身对象this作为key,value为变量的副本;
2.get()方法用于获取当前线程的副本变量值。
  set()方法用于保存当前线程的副本变量值。
  initialValue()为当前线程初始副本变量值。
  remove()方法移除当前线程的副本变量值。  

3.如何解决ThreadLocal的内存泄漏问题

4.案例

package com.gaoxinfu.demo.jdk.rt.java.lang.thread;

/**
 * @Description:
 * @Author: gaoxinfu
 * @Date: 2020-05-19 17:04
 */
public class ThreadLocalDemo {

    private static ThreadLocal<String> nameThreadLocal=new ThreadLocal<String>(){
        @Override
        protected String initialValue() {
            return "gaoxinfu";
        }
    };

    public static void main(String[] args) {
        for (int i=0;i<5;i++){
            new Thread(()->{
                System.out.println("Thread Name = "+Thread.currentThread().getName()+",Name = "+nameThreadLocal.get());
            },"thread"+i).start();
        }

    }
}

com.gaoxinfu.demo.jdk.rt.java.lang.thread.ThreadLocalDemo
Thread Name = thread0,Name = gaoxinfu
Thread Name = thread1,Name = gaoxinfu
Thread Name = thread2,Name = gaoxinfu
Thread Name = thread3,Name = gaoxinfu
Thread Name = thread4,Name = gaoxinfu
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

东山富哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值