ThreadLocal的使用和理解

21 篇文章 0 订阅
  • 我们在定义一般的类成员变量时,他们在线程间是不隔离的,也就是在多线程环境下,一个线程这个变量的改变会影响另一个线程对这个值得读取。ThreadLocal创建的变量可以实现线程间数据的隔离。

举个例子:

	public class MyClass{
	    ThreadLocal<String> threadLocal;
	    String string;
	    //测试使用Threadlocal;
	   public void test(){
        threadLocal=new ThreadLocal<>();
        Runnable runnable = new Runnable() {
            @Override
            public void run() {
                threadLocal.set("润1");
                string="123";
                System.out.println("设置完毕");
            }
        };
        Runnable runnable1 = new Runnable() {
            @Override
            public void run() {
                String s = threadLocal.get();
                System.out.println("ThreadLocal结果:" + s);
                System.out.println("string结果"+string);
            }
        };
        Thread thread1=new Thread(runnable);
        Thread thread2=new Thread(runnable1);
        thread1.start();
        thread2.start();
    }
}

以上代码的执行结果:
在这里插入图片描述

  • 底层如何实现?
    每一個Thread里面都有会声明这样的一个变量ThreadLocal.ThreadLocalMap threadLocals = null;。当我们调用ThreadLocal的set方法时,他先获取当前线程,再获取当前线程的threadLocalMap变量。另外threadLocalMap中也是用了entry来存储,且这是个弱引用。
    • 总结:也就是说线程之间的隔离其实是通过在不同线程中声明一个threadLocals变量实现的。而entry使用弱引用主要是为了防止内存泄漏,因为我们声明的threadLocal对象不仅仅在我们代码中引用了,还在线程中也会使用它作为key,当我们代码中没使用,但线程还存在时就会发生内存泄漏的问题,所以使用弱引用能=更好的防止内存泄漏,不过最好的方法还是在将threadLocal对象使用完后在代码中使用remove方法。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CompletableFuture 是 Java 8 中引入的一个用于处理异步编程的类,它提供了一些方法来处理异步操作的结果。循环使用 CompletableFuture 可以通过一种方式来组合多个异步操作,并且在所有操作完成后获取结果。 在循环使用 CompletableFuture 时,可以结合 ThreadLocal 来实现线程局部变量的功能。ThreadLocal 是 Java 中的一个线程封闭机制,它允许每个线程都有自己独立的变量副本,可以在多线程环境中实现数据隔离。 下面是一个示例代码,演示了如何循环使用 CompletableFuture 并结合 ThreadLocal 使用: ```java import java.util.concurrent.CompletableFuture; public class CompletableFutureExample { private static ThreadLocal<Integer> threadLocal = new ThreadLocal<>(); public static void main(String[] args) { for (int i = 1; i <= 10; i++) { int value = i; CompletableFuture<Integer> future = CompletableFuture.supplyAsync(() -> { // 在这里可以使用 threadLocal 获取当前线程的变量 Integer previousValue = threadLocal.get(); if (previousValue != null) { // 使用之前的进行计算 return previousValue + value; } else { return value; } }).thenApply(result -> { // 在这里可以使用 threadLocal 设置当前线程的变量 threadLocal.set(result); return result; }); future.thenAccept(result -> System.out.println("Result: " + result)); } } } ``` 在上面的代码中,我们定义了一个 ThreadLocal 变量 `threadLocal`,并在每个 CompletableFuture 中使用它来保存当前线程的局部变量。在每个 CompletableFuture 的计算过程中,我们可以通过 `threadLocal.get()` 获取之前的,并且可以通过 `threadLocal.set(result)` 设置当前线程的。 需要注意的是,在使用 ThreadLocal 时要确保对其进行适当的清理,以避免可能的内存泄漏。可以在代码的适当位置调用 `threadLocal.remove()` 来清理 ThreadLocal 变量。 希望上述示例能够帮助你理解 CompletableFuture 如何与 ThreadLocal 搭配使用
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值