异步线程threadLocal中对象获取失败

问题描述

在一个比较复杂的业务中,同步执行了主任务,将与当前任务无关的任务丢进了异步线程,然后发现异步线程没有获取到用户。所有的异步任务都没有执行下去。

排查

1.直接debug,发现任务在异步方法开始执行就失败了,没有进入异步方法;
2.打log,异步方法前的log打印了,之后的没有。
3.仔细看代码,发现了开启异步线程后入参直接来自threadLocal,找到问题了,明显的子线程获取父线程对象问题。

解决

直接先获取父线程的对象,然后传递到子线程。

思考

如果是简单的父线程向子线程传值直接把对象传过去就完事
如果涉及到子线程和父线程之间的交互,那么就需要更加复杂的操作了,ThreadLocal和InheritableThreadLocal深入分析这篇文章可以解惑

发布了212 篇原创文章 · 获赞 64 · 访问量 27万+

猜你喜欢

转载自blog.csdn.net/qq_26400953/article/details/104964177