如何解决Java单线程中ThreadLocal变量引发的问题?
- 内容介绍
- 文章标签
- 相关推荐
本文共计368个文字,预计阅读时间需要2分钟。
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
运行结果第一次
第二次
按理说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分钟。
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
运行结果第一次
第二次
按理说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线程池。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。

