ThreadLocal中存储用户id,但是使用多线程处理业务时ThreadLocal则无法获取,因为不是同一线程。现在我不想使用全局变量传参,而是还可以在多线程中从ThreadLocal中获取并且值不变,MDC可以解决但是不是完全理解,还望各位指教😀
3条回答 默认 最新
- 追cium 2023-03-19 15:49关注
参考GPT和自己的思路:
ThreadLocal中存储的值只能在同一个线程内获取,如果在多线程处理业务时需要从ThreadLocal中获取值,并且值不能改变,可以考虑使用InheritableThreadLocal。
InheritableThreadLocal可以实现不同线程间的值传递。当子线程被创建时,子线程会继承父线程中的InheritableThreadLocal值,子线程的修改不会影响父线程中的值。具体实现方法如下:
public class MyThreadLocal { public static InheritableThreadLocal<Long> userThreadLocal = new InheritableThreadLocal<>(); public static void set(Long value) { userThreadLocal.set(value); } public static Long get() { return userThreadLocal.get(); } public static void remove() { userThreadLocal.remove(); } } // 在主线程中设置值 MyThreadLocal.set(userId); // 在子线程中获取值 Long userId = MyThreadLocal.get();
当然,MDC也可以实现多线程中传递值的需求,但其使用场景更多的是日志记录,不符合本问题的要求。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报