欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java 異步線程監(jiān)聽(tīng)與結(jié)果回調(diào)及異常捕獲總結(jié)分析

 更新時(shí)間:2021年11月02日 15:35:01   作者:劍客阿良_ALiang  
異常是程序之中導(dǎo)致程序中斷的一種指令流,異常一旦出現(xiàn)并且沒(méi)有進(jìn)行合理處理的話,那么程序就將中斷執(zhí)行,這篇文章綜合介紹了異步線程監(jiān)聽(tīng)與結(jié)果回調(diào)及異常捕獲

前言

工作中是否遇到這樣的場(chǎng)景?

1、需要異步線程執(zhí)行,而且需要獲取到線程執(zhí)行返回的結(jié)果。

2、如果執(zhí)行過(guò)程異常,可以按照自定義方式消費(fèi)異常信息。

如果只是單純的使用Callable可以實(shí)現(xiàn),本文提供更加優(yōu)雅的工具類(lèi)。

Maven依賴(lài)

        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-all</artifactId>
            <version>5.7.15</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/com.google.guava/guava -->
        <dependency>
            <groupId>com.google.guava</groupId>
            <artifactId>guava</artifactId>
            <version>31.0.1-jre</version>
        </dependency>

代碼

不廢話,上代碼。

package com.huyi.csdn.tools;
 
import cn.hutool.core.thread.ThreadUtil;
import com.google.common.util.concurrent.*;
import org.checkerframework.checker.nullness.qual.Nullable;
import org.springframework.scheduling.concurrent.CustomizableThreadFactory;
 
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;
import java.util.function.Consumer;
 
/**
 * @Program: csdn @ClassName: AsyncListenUtil @Author: huyi @Date: 2021-10-30 11:48 @Description:
 * 異步線程監(jiān)聽(tīng)回調(diào)工具 @Version: V1.0
 */
public class AsyncListenUtil {
  public static final ExecutorService executorService =
      Executors.newFixedThreadPool(10, new CustomizableThreadFactory("LISTEN-"));
  public static final ListeningExecutorService listeningExecutorService =
      MoreExecutors.listeningDecorator(executorService);
 
  /**
   * 提交任務(wù)
   *
   * @param work Callable需要線程執(zhí)行的內(nèi)容
   * @param consumer 結(jié)果消費(fèi)
   * @param errorConsumer 異常消費(fèi)
   * @param <T> 泛型
   */
  public static <T> void submit(
      Callable<T> work, Consumer<T> consumer, Consumer<Throwable> errorConsumer) {
    ListenableFuture<T> listenableFuture = listeningExecutorService.submit(work);
    Futures.addCallback(
        listenableFuture,
        new FutureCallback<T>() {
          @Override
          public void onSuccess(@Nullable T s) {
            consumer.accept(s);
          }
 
          @Override
          public void onFailure(Throwable throwable) {
            errorConsumer.accept(throwable);
          }
        },
        listeningExecutorService);
  }
 
  /** 摧毀線程池 */
  public static void destroy() {
    System.out.println("摧毀線程池");
    executorService.shutdown();
  }
 
  public static void main(String[] args) {
    AsyncListenUtil.submit(
        () -> {
          // todo 需要執(zhí)行的內(nèi)容
          ThreadUtil.sleep(10, TimeUnit.SECONDS);
          return "I finished my work";
        },
        result -> {
          // todo 結(jié)果處理
          System.out.println("listen get :" + result);
        },
        throwable -> {
          // todo 異常處理
          System.out.println(throwable.getMessage());
        });
    ThreadUtil.sleep(20, TimeUnit.SECONDS);
    destroy();
  }
}

代碼說(shuō)明

1、提交方法主要參數(shù)有,需要執(zhí)行的Callable,結(jié)果的Consumer,異常的Consumer。其中Callable調(diào)整成Supplier也是沒(méi)什么問(wèn)題。

2、提供摧毀線程池方法。

執(zhí)行結(jié)果

OK沒(méi)什么問(wèn)題。

總結(jié)

追求優(yōu)雅是個(gè)好習(xí)慣。

如果本工具對(duì)你有用的話,請(qǐng)點(diǎn)個(gè)贊吧,這對(duì)作者很重要,謝謝。

到此這篇關(guān)于Java 異步線程監(jiān)聽(tīng)與結(jié)果回調(diào)及異常捕獲總結(jié)分析的文章就介紹到這了,更多相關(guān)Java 異步線程監(jiān)聽(tīng)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論