二七零零 2022-08-16 18:39 采纳率: 66.7%
浏览 18
已结题

guava ListenableFuture 多线程ava.lang.NullPointerException

问题遇到的现象和发生背景

一段多线程的代码,时不时出现报错,非必现,望帮忙解决

问题相关代码,请勿粘贴截图

 List<ListenableFuture<Object>> listenableFutureList = Lists.newArrayList();
        for (String dataKey : dataKeySet) {
                listenableFutureList.add(asyncQueryManager.submit(() -> tollTimeStatisticsDomainServiceV4.moneyTime(queryParam)));
                listenableFutureList.add(asyncQueryManager.submit(() -> tollTimeStatisticsDomainServiceV4.chainRatioTollTime(queryParam)));
                listenableFutureList.add(asyncQueryManager.submit(() -> tollTimeStatisticsDomainServiceV4.chargeFreeStatistics(queryParam)));
                listenableFutureList.add(asyncQueryManager.submit(() -> tollTimeStatisticsDomainServiceV4.moneyRecoverTime(queryParam)));
                listenableFutureList.add(asyncQueryManager.submit(() -> tollTimeStatisticsDomainServiceV4.chainFromPreiod(queryParam)));
                listenableFutureList.add(asyncQueryManager.submit(() -> tollTimeStatisticsDomainServiceV4.feeGrowthTrend(queryParam)));
                listenableFutureList.add(asyncQueryManager.submit(() -> tollTimeStatisticsDomainServiceV4.annualFeeTarget(queryParam)));
        }
        List resultList = asyncQueryManager.getTaskListResult(10L, listenableFutureList);
        Map<String, Object> result = Maps.newHashMap();
        if (CollectionUtils.isNotEmpty(resultList)) {
            resultList.stream().forEach(a -> result.putAll((Map<String, Object>) a));
        }
public List getTaskListResult(Long waitSeconds,Collection<ListenableFuture<Object>> listenableFutures) {
        ListenableFuture[] array = new ListenableFuture[listenableFutures.size()];
        return getTaskResult(waitSeconds,listenableFutures.toArray(array));
    }

    // 获取异步线程结果等待时间,单位:秒
    public List<Object> getTaskResult(Long waitSeconds,ListenableFuture<Object> ...listenableFutures){
        waitSeconds = getWaitSeconds(waitSeconds);
        try {
            if(ObjectUtils.isEmpty(listenableFutures)){
                return null;
            }else{
                return Futures.allAsList(listenableFutures).get(waitSeconds, TimeUnit.SECONDS);
            }
        } catch (InterruptedException e) {
            log.error("等待处理结果时被打断",e);
//            Thread.currentThread().interrupt();
        } catch (ExecutionException e) {
            e.printStackTrace();
            log.error("ExecutionException",e);
        } catch (TimeoutException e) {
            e.printStackTrace();
            log.error("等待处理结果超时",e);
        }
        return null;
    }

运行结果及报错内容

java.util.concurrent.ExecutionException: java.lang.NullPointerException
    at com.google.common.util.concurrent.AbstractFuture.getDoneValue(AbstractFuture.java:564)
    at com.google.common.util.concurrent.AbstractFuture.get(AbstractFuture.java:443)
    at com.google.common.util.concurrent.AbstractFuture$TrustedFuture.get(AbstractFuture.java:109)
    at com.hiscene.hds.opendata.server.common.AsyncQueryManager.getTaskResult(AsyncQueryManager.java:87)
    at com.hiscene.hds.opendata.server.common.AsyncQueryManager.getTaskListResult(AsyncQueryManager.java:72)
    at com.hiscene.hds.opendata.server.submodule.toll.service.app.TollStatisticsServiceV4.getTollStatisticsData(TollStatisticsServiceV4.java:71)
    at com.hiscene.hds.opendata.server.submodule.toll.controller.TollStatisticsControllerV4.getTollStatisticsData$original$Dyd6AcbV(TollStatisticsControllerV4.java:47)
    at com.hiscene.hds.opendata.server.submodule.toll.controller.TollStatisticsControllerV4.getTollStatisticsData$original$Dyd6AcbV$accessor$BTxWJmE3(TollStatisticsControllerV4.java)
    at com.hiscene.hds.opendata.server.submodule.toll.controller.TollStatisticsControllerV4$auxiliary$AaENxvHt.call(Unknown Source)
    at org.apache.skywalking.apm.agent.core.plugin.interceptor.enhance.InstMethodsInter.intercept(InstMethodsInter.java:86)
    at com.hiscene.hds.opendata.server.submodule.toll.controller.TollStatisticsControllerV4.getTollStatisticsData(TollStatisticsControllerV4.java)
    at com.hiscene.hds.opendata.server.submodule.toll.controller.TollStatisticsControllerV4$$FastClassBySpringCGLIB$$f039dc71.invoke(<generated>)
    at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218)
    at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:771)
    at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:163)
    at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:749)
    at org.springframework.aop.aspectj.MethodInvocationProceedingJoinPoint.proceed(MethodInvocationProceedingJoinPoint.java:100)
    at com.hiscene.config.RequestAccessLogConfiguration.paramsLogAndTimeAround(RequestAccessLogConfiguration.java:78)
    at sun.reflect.GeneratedMethodAccessor237.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.springframework.aop.aspectj.AbstractAspectJAdvice.invokeAdviceMethodWithGivenArgs(AbstractAspectJAdvice.java:644)
    at org.springframework.aop.aspectj.AbstractAspectJAdvice.invokeAdviceMethod(AbstractAspectJAdvice.java:633)
    at org.springframework.aop.aspectj.AspectJAroundAdvice.invoke(AspectJAroundAdvice.java:70)
    at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:175)
    at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:749)
    at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:95)
    at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186)
    at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:749)
    at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:691)
    at com.hiscene.hds.opendata.server.submodule.toll.controller.TollStatisticsControllerV4$$EnhancerBySpringCGLIB$$e0cb6de7.getTollStatisticsData(<generated>)
    at sun.reflect.GeneratedMethodAccessor363.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:190)
    at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:138)
    at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:105)
    at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:878)
    at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:792)
    at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87)
    at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1040)
    at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:943)
    at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006)
    at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:909)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:665)
    at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:750)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
    at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
    at brave.servlet.TracingFilter.doFilter(TracingFilter.java:68)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
    at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:100)
    at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
    at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:93)
    at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
    at brave.servlet.TracingFilter.doFilter(TracingFilter.java:87)
    at org.springframework.cloud.sleuth.instrument.web.LazyTracingFilter.doFilter(TraceWebServletAutoConfiguration.java:139)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
    at org.springframework.boot.actuate.metrics.web.servlet.WebMvcMetricsFilter.doFilterInternal(WebMvcMetricsFilter.java:93)
    at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
    at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201)
    at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:202)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541)
    at org.apache.catalina.core.StandardHostValve.invoke$original$fB9z2Ve3(StandardHostValve.java:139)
    at org.apache.catalina.core.StandardHostValve.invoke$original$fB9z2Ve3$accessor$HYrkMTVo(StandardHostValve.java)
    at org.apache.catalina.core.StandardHostValve$auxiliary$3ZOx8fIV.call(Unknown Source)
    at org.apache.skywalking.apm.agent.core.plugin.interceptor.enhance.InstMethodsInter.intercept(InstMethodsInter.java:86)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:74)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)
    at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:373)
    at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65)
    at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:868)
    at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1589)
    at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
    at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
    at java.lang.Thread.run(Thread.java:748)
Caused by: java.lang.NullPointerException: null

我的解答思路和尝试过的方法

1、加入为空判断

  if(ObjectUtils.isEmpty(listenableFutures)){
                return null;
            }else{
                return Futures.allAsList(listenableFutures).get(waitSeconds, TimeUnit.SECONDS);
            }

2、估计是线程中的自己实现的方法有问题,但如果是线程中的自己实现的方法报错,抛出的异常会显示出来,现在是无显示

  • 写回答

0条回答 默认 最新

    报告相同问题?

    问题事件

    • 系统已结题 8月24日
    • 创建了问题 8月16日

    悬赏问题

    • ¥15 is not in the mmseg::model registry。报错,模型注册表找不到自定义模块。
    • ¥15 安装quartus II18.1时弹出此error,怎么解决?
    • ¥15 keil官网下载psn序列号在哪
    • ¥15 想用adb命令做一个通话软件,播放录音
    • ¥30 Pytorch深度学习服务器跑不通问题解决?
    • ¥15 部分客户订单定位有误的问题
    • ¥15 如何在maya程序中利用python编写领子和褶裥的模型的方法
    • ¥15 Bug traq 数据包 大概什么价
    • ¥15 在anaconda上pytorch和paddle paddle下载报错
    • ¥25 自动填写QQ腾讯文档收集表