如何解决Java单线程中ThreadLocal变量引发的问题?

2026-05-26 08:271阅读0评论SEO基础
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计368个文字,预计阅读时间需要2分钟。

如何解决Java单线程中ThreadLocal变量引发的问题?

ThreadLocal 用于在线程间隔离变量,确保每个线程都有自己的变量副本,从而避免共享变量带来的线程安全问题。在方法或类间共享变量的场景中,ThreadLocal 非常适用。

java@RestControllerpublic class ThreadLocalController { private static final ThreadLocal currentUid=ThreadLocal.withInitial(() -> );}

ThreadLocal

ThreadLocal 适用于变量在线程间隔离,而在方法或类间共享的场景。

代码

@RestController public class ThreadLocalController { private static final ThreadLocal<String> currentUid = ThreadLocal.withInitial(() -> null); @GetMapping("bad") public Map doBad(@RequestParam("uid") String uid) { String before = currentUid.get(); currentUid.set(uid); String after = currentUid.get(); Map result = new HashMap(); result.put("before", before); result.put("after", after); return result; } }

在application中做一下tomcat的配置

server.tomcat.max-threads=1

运行结果第一次

第二次

如何解决Java单线程中ThreadLocal变量引发的问题?

按理说before总是null才对,为什么第二次运行却读取到了第一次的值呢?

只是因为我们的tocat会开启一个线程来调用我们的程序,而tomcat本身是有线程池的,会出现线程复用的情况。所以导致了问题。

修复

@RestController public class ThreadLocalController { private static final ThreadLocal<String> currentUid = ThreadLocal.withInitial(() -> null); @GetMapping("good") public Map doGood(@RequestParam("uid") String uid) { try { String before = currentUid.get(); currentUid.set(uid); String after = currentUid.get(); Map result = new HashMap(); result.put("before", before); result.put("after", after); return result; } finally { currentUid.remove(); } } }

Key

tomcat线程池。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。

本文共计368个文字,预计阅读时间需要2分钟。

如何解决Java单线程中ThreadLocal变量引发的问题?

ThreadLocal 用于在线程间隔离变量,确保每个线程都有自己的变量副本,从而避免共享变量带来的线程安全问题。在方法或类间共享变量的场景中,ThreadLocal 非常适用。

java@RestControllerpublic class ThreadLocalController { private static final ThreadLocal currentUid=ThreadLocal.withInitial(() -> );}

ThreadLocal

ThreadLocal 适用于变量在线程间隔离,而在方法或类间共享的场景。

代码

@RestController public class ThreadLocalController { private static final ThreadLocal<String> currentUid = ThreadLocal.withInitial(() -> null); @GetMapping("bad") public Map doBad(@RequestParam("uid") String uid) { String before = currentUid.get(); currentUid.set(uid); String after = currentUid.get(); Map result = new HashMap(); result.put("before", before); result.put("after", after); return result; } }

在application中做一下tomcat的配置

server.tomcat.max-threads=1

运行结果第一次

第二次

如何解决Java单线程中ThreadLocal变量引发的问题?

按理说before总是null才对,为什么第二次运行却读取到了第一次的值呢?

只是因为我们的tocat会开启一个线程来调用我们的程序,而tomcat本身是有线程池的,会出现线程复用的情况。所以导致了问题。

修复

@RestController public class ThreadLocalController { private static final ThreadLocal<String> currentUid = ThreadLocal.withInitial(() -> null); @GetMapping("good") public Map doGood(@RequestParam("uid") String uid) { try { String before = currentUid.get(); currentUid.set(uid); String after = currentUid.get(); Map result = new HashMap(); result.put("before", before); result.put("after", after); return result; } finally { currentUid.remove(); } } }

Key

tomcat线程池。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。