Java异步编程之CompletableFuture

本文详细介绍了Java中的CompletableFuture和Future,讲解了如何使用CompletableFuture进行异步编程,包括线程池的使用、异常处理、CompletionStage接口的理解以及批量执行异步任务的CompletionService。强调了在实际应用中,应根据业务创建不同线程池以避免资源耗尽和线程饥饿,同时提醒开发者关注异常处理和线程池配置。
摘要由CSDN通过智能技术生成

异步任务

Future获取异步任务结果

利用 Java 并发包提供的 Future 可以很容易获得异步任务的执行结果,无论异步任务是通过线程池 ThreadPoolExecutor 执行的,还是通过手工创建子线程来执行的。利用多线程可以快速将一些串行的任务并行化,从而提高性能;如果任务之间有依赖关系,比如当前任务依赖前一个任务的执行结果,这种问题基本上都可以用 Future 来解决。

其类结构如下:

public interface Future<V> {
  boolean cancel(boolean mayInterruptIfRunning);
  
  boolean isCancelled();

  boolean isDone();

  V get() throws InterruptedException, ExecutionException;

  V get(long timeout, TimeUnit unit)
        throws InterruptedException, ExecutionException, TimeoutException;
 }
复制代码

方法解释如下:

Future 备注
cancel(boolean) 尝试取消异步任务的执行。如果任务已经执行完成、已经被取消、因为某种原因不能被取消,则返回false;如果任务正在执行,并且mayInterruptIfRunning为true,那么会调用interrupt()尝试打断任务。该方法返回结果后,isDone()总会返回true
isCancelled() 如果在任务完成前被取消,返回true
isDone() 如果任务完成则返回true。任务完成包括正常结束、任务被取消、任务发生异常,都返回true
get() 获取异步任务执行结果,如果没有返回,则阻塞等待
get(long timeout, TimeUnit unit) 在给定的时间内等待获取异步任务结果,如果超时还未获取到结果,则会抛出TimeoutException

但它本身只是一个接口,还需要看Future的具体实现类:

红色框起来的就是常见的实现类,就不一一展开赘述了,这里以FutureTask的使用为例:

 //初始化一个线程池
 ExecutorService executor = = Executors.newSingleThreadExecutor();
 //new 一个Callable并传入FutureTask
 FutureTask<String> future =new FutureTask<>(new Callable<String>() {
     public String call() {
        //do something
       return result;
   }});
 executor.execute(future);
 //在异步任务执行期间可以做一些其他的事情
 displayOtherThings();
 //通过future.get()得到异步任务执行结果
 String result=future.get();
复制代码

CompletableFuture异步编程

CompletableFuture的线程池之坑

CompletableFuture又是如何创建新线程的?答案是ForkJoinPool.commonPool() ,我们熟悉的老朋友又回来了,还是它。当需要新的线程时,CompletableFuture会

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值