线上接口经常超时,我用线程池+ FutureTask解决了,YYDS
作者:zhongh Jim
来源:blog.csdn.net/qq_44384533/article/details/112324224
之前红包权益领取查询的接口超时了,因为有用户订购的权益有点多
解决方案:
public class Test {//线程池最好作为全局变量, 若作为局部变量记得用完后shutdown()ThreadFactory namedThreadFactory = new ThreadFactoryBuilder().setNameFormat("thread-start-runner-%d").build();ExecutorService taskExe= new ThreadPoolExecutor(10,20,800L, TimeUnit.MILLISECONDS,new LinkedBlockingQueue(100),namedThreadFactory); int count=0;@Testpublic void test(String[] args) {//任务列表List> taskList=new ArrayList >(); for(int i=0;i<100;i++){//创建100个任务放入【任务列表】FutureTaskfutureTask=new FutureTask (new Callable () { @Overridepublic Integer call() throws Exception {return 1;}});//执行的结果装回原来的FutureTask中,后续直接遍历集合taskList来获取结果即可taskList.add(futureTask);taskExe.submit(futureTask);}//获取结果try{for(FutureTaskfutureTask:taskList){ count+=futureTask.get();}} catch (InterruptedException e) {logger.error("线程执行被中断",e);} catch (ExecutionException e) {logger.error("线程执行出现异常",e);}//关闭线程池taskExe.shutdown();//打印: 100System.out.println(count);}}
子线程出的异常抛不出的情况
如果你的代码没有调用FutureTask.get(),它不会把异常吐出来,有可能子线程就莫名的停止了。
public Future> submit(Runnable task) {if (task == null) throw new NullPointerException();//创建一个异步执行的任务FutureTask, 【隐患】也在它的run()代码块里RunnableFutureftask = newTaskFor(task, null); execute(ftask);return ftask;}
正文结束
1.救救大龄码农!45岁程序员在国务院网站求助总理!央媒网评来了...
5.37岁程序员被裁,120天没找到工作,无奈去小公司,结果懵了...

评论
