已解决java.util.concurrent.CancellationException: 取消异常的正确解决方法,亲测有效!!!
目录
java.util.concurrent.CancellationException
通常在尝试获取已取消的任务的结果时抛出。这个异常在使用Future
接口和相关的并发API时特别常见。如果任务被取消,尝试获取其结果将导致此异常。
主要原因包括:
Future.cancel(boolean)
方法被显式取消。ExecutorService
的并发工具管理任务时,尝试获取已取消任务的结果。要解决这个异常,关键在于妥善管理任务的生命周期,确保正确处理取消的情况:
在尝试获取任务结果之前,先检查任务是否已被取消。
- Future
future = executor.submit(callableTask); -
- if (!future.isCancelled()) {
- try {
- String result = future.get();
- System.out.println("Task completed with result: " + result);
- } catch (InterruptedException | ExecutionException e) {
- e.printStackTrace();
- }
- } else {
- System.out.println("Task was cancelled.");
- }
在任务可能被取消的环境中,捕获并妥善处理CancellationException
。
- try {
- String result = future.get();
- } catch (CancellationException e) {
- System.err.println("Attempted to retrieve result of a cancelled task.");
- } catch (InterruptedException | ExecutionException e) {
- e.printStackTrace();
- }
如果任务被取消,提供适当的用户反馈或进行清理操作。
- if (future.cancel(true)) {
- System.out.println("Task was successfully cancelled.");
- } else {
- System.out.println("Failed to cancel task.");
- }
使用ExecutorService
时,确保在结束应用前正确关闭执行器,处理所有任务的取消或完成。
- ExecutorService executor = Executors.newFixedThreadPool(2);
- // 添加任务到执行器
- // ...
-
- // 关闭执行器,等待未完成任务结束
- executor.shutdown();
- try {
- if (!executor.awaitTermination(800, TimeUnit.MILLISECONDS)) {
- executor.shutdownNow();
- }
- } catch (InterruptedException e) {
- executor.shutdownNow();
- }
处理java.util.concurrent.CancellationException
需要在设计并发应用时,预见并管理任务的生命周期。理解任务取消的时机和原因对于开发健壁的并发应用至关重要。通过在代码中添加适当的检查和异常处理,可以确保程序的健壮性和用户的良好体验。正确地管理任务取消,不仅可以避免不必要的计算资源浪费,还可以提高应用的响应性和效率。
以上是此问题报错原因的解决方法,欢迎评论区留言讨论是否能解决,如果本文对你有帮助 欢迎 关注 、点赞 、收藏 、评论, 博主才有动力持续记录遇到的问题!!!
📫作者简介:嗨,大家好,我是 小明(小明Java问道之路),互联网大厂后端研发专家,2022博客之星TOP3 / 博客专家 / CSDN后端内容合伙人、InfoQ(极客时间)签约作者、阿里云签约博主、全网 6 万粉丝博主。
🍅 文末获取联系 🍅 👇🏻 精彩专栏推荐订阅收藏 👇🏻
专栏系列(点击解锁)
学习路线(点击解锁)
知识定位
全面讲解MySQL知识与企业级MySQL实战 🔥计算机底层原理🔥