业务需求拿到多个接口返回的信息集合,并通过判断对比整合数据,考虑可能并发比较高,所以引用线程池来完成;
可返回值的任务必须实现Callable接口。
执行Callable任务后,可以获取一个Future的对象,在该对象上调用get就可以获取到Callable任务返回的Object了。
创建一个线程池,在线程中调用其他接口来实现业务需求,并把结果返回,例子如下:
// 创建一个线程池
ExecutorService executorService = Executors.newFixedThreadPool(3);
List<Future> list = new ArrayList<>();
// 执行任务并获取Future对象
String requestId = LogUtil.getCurrentRequestId();
RequestAttributes requestAttributes = RequestContextHolder.getRequestAttributes();
// 多线程实现商品状态线程
Future goodsStautsFuture =
executorService.submit(
new Callable<String>() {
@Override
public String call() throws Exception {
LogUtil.setRequestId(requestId);
RequestContextHolder.setRequestAttributes(requestAttributes);
GetCartOrderOhterMsgResultDto result &