您的代码建议您稍后在同一方法中使用异步操作的结果,因此您无论如何都必须处理CompletionException,因此处理它的一种方法是

public void myFunc() throws ServerException {

// Some code

CompletableFuture a = CompletableFuture.supplyAsync(() -> {

try { return someObj.someFunc(); }

catch(ServerException ex) { throw new CompletionException(ex); }

});

// Some code running in parallel to someFunc()

A resultOfA;

try {

resultOfA = a.join();

}

catch(CompletionException ex) {

try {

throw ex.getCause();

}

catch(Error|RuntimeException|ServerException possible) {

throw possible;

}

catch(Throwable impossible) {

throw new AssertionError(impossible);

}

}

// some code using resultOfA

}

除了我们已经包含在CompletionException中的ServerException之外,在调用join时,在Supplier的异步处理中抛出的所有异常都将被包装到CompletionException中.

当我们重新抛出CompletionException的原因时,我们可能会遇到未经检查的异常,即Error或RuntimeException的子类,或者我们的自定义检查异常ServerException.上面的代码使用multi-catch处理所有这些代码,它们将重新抛出它们.由于getCause()的声明返回类型是Throwable,编译器要求我们处理该类型,尽管我们已经处理了所有可能的类型.直接的解决方案是抛出一个包含在AssertionError中的实际上不可能的throwable.

或者,我们可以为我们的自定义异常使用替代结果:

public void myFunc() throws ServerException {

// Some code

CompletableFuture exception = new CompletableFuture<>();

CompletableFuture a = CompletableFuture.supplyAsync(() -> {

try { return someObj.someFunc(); }

catch(ServerException ex) {

exception.complete(ex);

throw new CompletionException(ex);

}

});

// Some code running in parallel to someFunc()

A resultOfA;

try {

resultOfA = a.join();

}

catch(CompletionException ex) {

if(exception.isDone()) throw exception.join();

throw ex;

}

// some code using resultOfA

}

此解决方案将以其包装形式重新抛出所有“意外”throwable,但仅将自定义ServerException抛出其原始形式,通过异常将来传递.请注意,在我们查询异常未来之前,我们必须确保已完成a(如首先调用join()),以避免竞争条件.

java future 异常处理_java – 从CompletableFuture抛出异常相关推荐

  1. java future 异常处理_Java异常处理总结

    转自:http://blog.51cto.com/lavasoft/18920 Java异常处理总结 异常处理是程序设计中一个非常重要的方面,也是程序设计的一大难点,从C开始,你也许已经知道如何用if ...

  2. java批处理 异常处理_Java批处理教程

    java批处理 异常处理 在当今世界,互联网已经改变了我们的生活方式,其主要原因之一是大部分日常琐事都使用互联网. 这导致大量数据可用于处理. 其中涉及大量数据的一些示例是处理工资单,银行对帐单,利息 ...

  3. java 并发 异步_Java并发 CompletableFuture异步编程的实现

    前面我们不止一次提到,用多线程优化性能,其实不过就是将串行操作变成并行操作.如果仔细观察,你还会发现在串行转换成并行的过程中,一定会涉及到异步化,例如下面的示例代码,现在是串行的,为了提升性能,我们得 ...

  4. java future用法_Java中的多线程知识点

    如果对什么是线程.什么是进程仍存有疑惑,请先Google之,因为这两个概念不在本文的范围之内. 用多线程只有一个目的,那就是更好的利用cpu的资源,因为所有的多线程代码都可以用单线程来实现.说这个话其 ...

  5. java 运行异常处理_Java编程异常处理和I/O流

    重点: 1.在编写程序时,要正确地使用捕获例外和声明抛出异常的两种例外处理的方法. 2.遇到实际问题时,要根据需要正确使用各种输入/输出流,特别是对中文使用适当的字符输入流. 3.正确使用对象串行化的 ...

  6. java 开发者异常处理_Java异常处理和设计

    本篇博客内容转自http://www.cnblogs.com/dolphin0520/p/3769804.html,内容供自己学习参考之用 在程序设计中,进行异常处理是非常关键和重要的一部分.一个程序 ...

  7. java future接口_java Future 接口介绍

    在Java中,如果需要设定代码执行的最长时间,即超时,可以用Java线程池ExecutorService类配合Future接口来实现. Future接口是Java标准API的一部分,在java.uti ...

  8. java future 不足_java Future用法和意义一句话击破

    在并发编程时,一般使用runnable,然后扔给线程池完事,这种情况下不需要线程的结果. 所以run的返回值是void类型. 如果是一个多线程协作程序,比如菲波拉切数列,1,1,2,3,5,8...使 ...

  9. java spring异常处理_Java深入 - Spring 异常处理HandlerExceptionResolver

    spring的异常统一处理非常简单,首先我们需要看一下Spring中定义的HandlerExceptionResolver接口: /** * Interface to be implemented b ...

最新文章

  1. Java集合知识:TreeMap
  2. 任正非:中美领跑AI说法不合适、5G被炒作过热……
  3. Decision Tree
  4. Java 理论与实践: 用弱引用堵住内存泄漏---转载
  5. 如何做SEO项目管理?
  6. 响应式网页设计代码_消除响应式网站建设设计中的缺陷
  7. java.lang.NoSuchFieldError: EMPTY_ORDERED_ITERATOR起因及解决办法
  8. 二元函数最大最小值定理证明_代数基本定理,用复数证明所有多项式函数都有根...
  9. 当我设计游戏服务器时,我在想些什么?(1)
  10. js选择html元素,JavaScript中获取HTML元素值的三种方法
  11. 利用redis做次数限制的小结
  12. unity3d 台球源码_unity3D台球游戏源码
  13. 三对角、五对角追赶法求解线性方程组
  14. As a good Java programer
  15. 实战演习(四)——网络流量系统分析简介
  16. 红色的反色是青色引申出PS怎么反色之教程
  17. DAB-Deformable-DETR源码学习记录之模型构建(二)
  18. 「题解」:[线段树]:永无乡
  19. 权威指南:超融合基础参考架构(Nutanix)
  20. Intel Realsense L515 ros节点时间戳不同步解决方法

热门文章

  1. java之阻塞队列和非阻塞队列
  2. 平面设计之色彩搭配构成
  3. java内省技术,Java内省技术
  4. 双曲线焦点三角形的内切圆_Simplelife_新浪博客
  5. java permsize_Java中的“PermSize”是什么?
  6. 索引失效的几种情况和原因剖析
  7. 好看的皮囊千篇一律,内涵的“可视化大屏”万里挑一
  8. hbase查看表结构_HBase语法
  9. 11.购物车、SpringTask
  10. 【Python】Beta分布详解