作用域值:替代ThreadLocal的高效上下文传递
利用JEP 446的ScopedValue实现不可变、继承性上下文,零开销于虚拟线程。 · 难度:入门 · +10XP
作用域值:替代ThreadLocal的高效上下文传递
ThreadLocal在线程池和虚拟线程环境中存在内存泄漏和不可继承问题。ScopedValue通过绑定生命周期和作用域,在结构化并发下自动传递,且读取无额外内存开销。本教程展示如何用ScopedValue.where()创建临时绑定,并在子任务中自动继承。对比使用ThreadLocal传递用户身份信息时的陷阱,解释为何ScopedValue更适合虚拟线程。
import jdk.incubator.concurrent.*;
public class ScopedValueDemo {
private static final ScopedValue<String> USER = ScopedValue.newInstance();
public static void main(String[] args) {
ScopedValue.where(USER, "Alice")
.run(() -> {
System.out.println(USER.get());
// 内部fork的虚拟线程自动继承
});
}
}