Я пытаюсь выяснить, как я могу скопировать значение ThreadLocal в параллельном потоке Java 8.Java 8 параллельный поток и ThreadLocal
Так что, если мы считаем это:
public class ThreadLocalTest {
public static void main(String[] args) {
ThreadContext.set("MAIN");
System.out.printf("Main Thread: %s\n", ThreadContext.get());
IntStream.range(0,8).boxed().parallel().forEach(n -> {
System.out.printf("Parallel Consumer - %d: %s\n", n, ThreadContext.get());
});
}
private static class ThreadContext {
private static ThreadLocal<String> val = ThreadLocal.withInitial(() -> "empty");
public ThreadContext() {
}
public static String get() {
return val.get();
}
public static void set(String x) {
ThreadContext.val.set(x);
}
}
}
Какие выходы
Main Thread: MAIN
Parallel Consumer - 5: MAIN
Parallel Consumer - 4: MAIN
Parallel Consumer - 7: empty
Parallel Consumer - 3: empty
Parallel Consumer - 1: empty
Parallel Consumer - 6: empty
Parallel Consumer - 2: empty
Parallel Consumer - 0: MAIN
Есть ли способ для меня, чтобы клонировать ThreadLocal от основного метода() в нитях, которые порождены для каждой параллели исполнение?
Такое так, что мой результат:
Main Thread: MAIN
Parallel Consumer - 5: MAIN
Parallel Consumer - 4: MAIN
Parallel Consumer - 7: MAIN
Parallel Consumer - 3: MAIN
Parallel Consumer - 1: MAIN
Parallel Consumer - 6: MAIN
Parallel Consumer - 2: MAIN
Parallel Consumer - 0: MAIN
вместо первого?
Я бы так не ожидал. Но почему именно этот «ThreadLocal» в первую очередь, а не просто создан в вашем основном методе, а затем явно передан лямбда? –
Вы пытаетесь пересечь потоки? Я слышал, что это будет плохо. – zapl