java future 异常处理_java – 从CompletableFuture抛出异常
您的代码建议您稍后在同一方法中使用异步操作的结果,因此您无论如何都必须处理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抛出异常相关推荐
- java future 异常处理_Java异常处理总结
转自:http://blog.51cto.com/lavasoft/18920 Java异常处理总结 异常处理是程序设计中一个非常重要的方面,也是程序设计的一大难点,从C开始,你也许已经知道如何用if ...
- java批处理 异常处理_Java批处理教程
java批处理 异常处理 在当今世界,互联网已经改变了我们的生活方式,其主要原因之一是大部分日常琐事都使用互联网. 这导致大量数据可用于处理. 其中涉及大量数据的一些示例是处理工资单,银行对帐单,利息 ...
- java 并发 异步_Java并发 CompletableFuture异步编程的实现
前面我们不止一次提到,用多线程优化性能,其实不过就是将串行操作变成并行操作.如果仔细观察,你还会发现在串行转换成并行的过程中,一定会涉及到异步化,例如下面的示例代码,现在是串行的,为了提升性能,我们得 ...
- java future用法_Java中的多线程知识点
如果对什么是线程.什么是进程仍存有疑惑,请先Google之,因为这两个概念不在本文的范围之内. 用多线程只有一个目的,那就是更好的利用cpu的资源,因为所有的多线程代码都可以用单线程来实现.说这个话其 ...
- java 运行异常处理_Java编程异常处理和I/O流
重点: 1.在编写程序时,要正确地使用捕获例外和声明抛出异常的两种例外处理的方法. 2.遇到实际问题时,要根据需要正确使用各种输入/输出流,特别是对中文使用适当的字符输入流. 3.正确使用对象串行化的 ...
- java 开发者异常处理_Java异常处理和设计
本篇博客内容转自http://www.cnblogs.com/dolphin0520/p/3769804.html,内容供自己学习参考之用 在程序设计中,进行异常处理是非常关键和重要的一部分.一个程序 ...
- java future接口_java Future 接口介绍
在Java中,如果需要设定代码执行的最长时间,即超时,可以用Java线程池ExecutorService类配合Future接口来实现. Future接口是Java标准API的一部分,在java.uti ...
- java future 不足_java Future用法和意义一句话击破
在并发编程时,一般使用runnable,然后扔给线程池完事,这种情况下不需要线程的结果. 所以run的返回值是void类型. 如果是一个多线程协作程序,比如菲波拉切数列,1,1,2,3,5,8...使 ...
- java spring异常处理_Java深入 - Spring 异常处理HandlerExceptionResolver
spring的异常统一处理非常简单,首先我们需要看一下Spring中定义的HandlerExceptionResolver接口: /** * Interface to be implemented b ...
最新文章
- Java集合知识:TreeMap
- 任正非:中美领跑AI说法不合适、5G被炒作过热……
- Decision Tree
- Java 理论与实践: 用弱引用堵住内存泄漏---转载
- 如何做SEO项目管理?
- 响应式网页设计代码_消除响应式网站建设设计中的缺陷
- java.lang.NoSuchFieldError: EMPTY_ORDERED_ITERATOR起因及解决办法
- 二元函数最大最小值定理证明_代数基本定理,用复数证明所有多项式函数都有根...
- 当我设计游戏服务器时,我在想些什么?(1)
- js选择html元素,JavaScript中获取HTML元素值的三种方法
- 利用redis做次数限制的小结
- unity3d 台球源码_unity3D台球游戏源码
- 三对角、五对角追赶法求解线性方程组
- As a good Java programer
- 实战演习(四)——网络流量系统分析简介
- 红色的反色是青色引申出PS怎么反色之教程
- DAB-Deformable-DETR源码学习记录之模型构建(二)
- 「题解」:[线段树]:永无乡
- 权威指南:超融合基础参考架构(Nutanix)
- Intel Realsense L515 ros节点时间戳不同步解决方法