CompleteFuture与Future的比较

    • CompleteFuture的介绍
    • CompleteFuture的特点
    • CompleteFuture的应用场景
    • CompletableFuture的优缺点
    • Future的介绍
    • Future的特点
    • Future的应用场景
    • Future的优缺点
    • CompletableFuture和Future的区别
    • CompletableFuture和Future的关联关系
    • CompletableFuture和Future的使用示例
      • CompletableFuture使用示例
      • Future使用示例
    • CompletableFuture应用步骤

在这里插入图片描述

CompleteFuture的介绍

CompletableFuture是Java 8提供的一种基于Future的异步编程的实现。它不仅可以代表异步计算的结果,还能够定义它完成之后的回调函数。它的实现在java.util.concurrent.CompletableFuture的包内。

CompletableFuture的实现涉及到JDK 8的几个新特性,如Lambda、Stream、线程池等,它允许把任务池、线程池和阻塞队列组合在一起,使得开发者可以更加简单地实现异步编程,对程序的执行性能也带来了一定的提升。

与Future相比,CompletableFuture的优势在于:

  1. 可以直接对多个任务进行链式、组合等处理,而不需要借助并发工具类。
  2. 实现了对任务编排的能力,可以轻松地组织不同任务的运行顺序、规则以及方式。

CompleteFuture的特点

CompletableFuture的特点主要包括异步执行、链式操作和灵活性强

  1. 异步执行:CompletableFuture允许任务在后台线程中异步执行,不会阻塞主线程,提高了应用程序的响应性和性能。
  2. 链式操作:CompletableFuture支持链式操作,可以方便地处理任务的依赖关系和结果转换。
  3. 灵活性强:相比于传统的Future接口,CompletableFuture更加灵活和强大,提供了丰富的方法来处理异步操作和多个任务的结果。

CompleteFuture的应用场景

CompletableFuture的应用场景主要包括异步编程、任务组合和并发编程

  1. 异步编程:在需要执行耗时操作的情况下,使用CompletableFuture可以实现异步执行,避免阻塞主线程,提高程序的响应性和性能。
  2. 任务组合:CompletableFuture支持链式操作,可以将多个异步任务组合在一起,按照指定的顺序和逻辑执行,实现任务的依赖关系和结果转换。
  3. 并发编程:在多线程环境下,CompletableFuture可以方便地处理多个任务的结果,避免线程间的竞争和同步问题,提高并发编程的效率和可靠性。

CompletableFuture的优缺点

CompletableFuture的优点主要包括简洁易用、支持异步编程、任务组合和并发编程等。它提供了一种简洁的方式来处理异步计算和任务组合,使得异步编程更加容易和高效。

然而,CompletableFuture也存在一些缺点,例如:

  1. 无法对多个任务进行链式调用:如果希望在计算任务完成后执行特定动作,比如发邮件,但CompletableFuture却没有提供这样的能力。
  2. 无法组合多个任务:如果运行了10个任务,并期望在它们全部执行结束后执行特定动作,那么在CompletableFuture中这是无能为力的。
  3. 没有异常处理:CompletableFuture接口中没有关于异常处理的方法。

在这里插入图片描述

Future的介绍

Future是Java中用于异步计算的一个接口。它提供了一种方式,允许将一个耗时的计算任务放到另一个线程中执行,而主线程可以继续处理其他任务。

在Future接口中,通常包含一些方法,如isDone()、get()、cancel()等。isDone()方法用于检查Future是否已经完成,get()方法用于获取Future的结果,cancel()方法用于取消Future的计算任务。

使用Future接口可以实现异步计算,提高程序的执行效率。当需要执行一个耗时的计算任务时,可以创建一个Future对象,然后将该对象传递给异步线程执行。异步线程执行完成后,可以通过Future对象获取计算结果。


Future的特点

Future的特点主要有以下几个方面:

  1. 表示异步操作未完成时的状态:Future对象可以表示一个异步操作是否完成,如果异步操作未完成,Future对象的状态为未完成,如果异步操作完成,Future对象的状态为已完成。
  2. 可以用来获取异步操作完成后返回的结果:通过Future对象提供的get方法,可以获取异步操作完成后返回的结果。
  3. 不提供直接的方式来添加回调函数:Future不提供一种直接的方式来添加回调函数,处理操作完成后的结果或异常。
  4. 只能表示异步任务是否完成,而不能手动触发任务的完成或组合多个任务:Future只能表示异步任务是否完成,而不能手动触发任务的完成或组合多个任务。

Future的应用场景

Future的应用场景主要在并发编程中,当我们需要用到非阻塞的模型时,Future就显得尤为重要。

在Java多线程的三种实现中,无论是继承Thread类还是实现Runnable接口,都是异步的,并且主调函数无法获取到返回值。而Future则可以接收多线程的执行结果。具体来说,Future接收一个可能还没有完成的异步任务的结果,针对这个结果可以添加Callable以便任务执行成功或失败后作出相应的操作。

采用Future修改的异步方法,在每次被异步调用以后会马上返回(无论异步方法体是否执行完成),Future就会监听异步任务执行状态(成功、失败),等到执行完成以后,就能通过Future.get()方法获取到异步返回的结果。也就是说,如果批量调用采用Future修饰的异步方法,程序不会阻塞等待,然后再遍历Future列表,即可获取到所有的异步结果(Future的内部机制是等所有的异步任务完成了才进行遍历)。这种请求耗时只会略大于耗时最长的一个Future修饰的方法。


Future的优缺点

Future的优点主要包括:

  1. 异步处理:Future允许将耗时的计算任务放到另一个线程中执行,不会阻塞主线程,提高了程序的执行效率。
  2. 链式操作:Future支持链式操作,可以方便地处理任务的依赖关系和结果转换。

然而,Future也存在一些缺点:

  1. 阻塞获取结果:当需要获取Future的结果时,如果计算还没有完成,会导致程序阻塞。这可能会影响程序的性能和响应性。
  2. 无法添加回调函数:Future不提供一种直接的方式来添加回调函数,处理操作完成后的结果或异常。这使得在异步操作完成后,无法直接进行特定的处理。

在这里插入图片描述

CompletableFuture和Future的区别

CompletableFuture和Future的区别主要体现在以下几个方面:

  1. 功能区别 :Future只能用于获取异步计算的结果,而CompletableFuture除了能获取异步计算的结果外,还可以用于组合多个异步任务,处理异常情况,以及在任务完成时执行回调函数等。
  2. 阻塞区别 :Future的get方法是阻塞的,如果异步计算没有完成,它会一直等待直到计算完成。而CompletableFuture的get方法也是阻塞的,但是它可以设置超时时间,如果在指定的时间内计算没有完成,它会抛出TimeoutException异常。
  3. 异常处理区别 :Future的异常处理比较麻烦,需要在任务执行时捕获异常,然后将异常封装到Future对象中返回。而CompletableFuture的异常处理比较简单,可以使用exceptionally方法或handle方法来处理异常情况。
  4. 组合任务区别 :Future不支持组合多个异步任务,需要使用ExecutorService的submit方法来提交多个任务,并使用Future对象来获取每个任务的结果。而CompletableFuture支持组合多个异步任务,可以使用thenCompose、thenCombine、thenAcceptBoth等方法来组合多个任务。

CompletableFuture和Future的关联关系

CompletableFuture和Future之间存在关联关系,因为CompletableFuture实现了Future接口。这意味着CompletableFuture可以作为Future使用,同时它还提供了更多功能,如链式操作、异常处理和组合任务等。

CompletableFuture在内部使用了一个子线程来执行任务,并且提供了异步计算的结果。当异步计算完成时,CompletableFuture会自动将结果设置为已完成状态,并且可以通过get方法获取结果。

与Future相比,CompletableFuture提供了更多的功能和灵活性。它支持链式操作,可以将多个异步任务组合在一起,并且可以在任务完成后执行特定的回调函数。此外,CompletableFuture还提供了异常处理机制,可以捕获和处理任务执行过程中抛出的异常。

因此,CompletableFuture是Future的扩展和增强,它提供了更多的功能和灵活性,适用于需要处理异步计算和组合多个任务的场景。


CompletableFuture和Future的使用示例

CompletableFuture使用示例

以下是一个使用CompletableFuture的示例:

import java.util.concurrent.CompletableFuture;
import java.util.concurrent.ExecutionException;public class CompletableFutureExample {public static void main(String[] args) throws ExecutionException, InterruptedException {CompletableFuture<String> future = CompletableFuture.supplyAsync(() -> {// 模拟耗时操作try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}return "Hello, World!";});// 获取异步计算的结果String result = future.get();System.out.println(result);}
}

在这个示例中,我们使用CompletableFuture的supplyAsync方法创建了一个异步任务,该任务会返回一个字符串"Hello, World!"。然后,我们使用get方法获取异步计算的结果,并将其打印出来。这个示例演示了如何使用CompletableFuture来执行异步计算并获取结果。

Future使用示例

以下是一个使用Java Future的示例:

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;public class FutureExample {public static void main(String[] args) throws Exception {ExecutorService executor = Executors.newSingleThreadExecutor();// 提交任务并获取Future对象Future<String> future = executor.submit(() -> {// 模拟耗时操作try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}return "Hello, World!";});// 获取异步计算的结果String result = future.get();System.out.println(result);// 关闭ExecutorServiceexecutor.shutdown();}
}

在这个示例中,我们使用ExecutorService的submit方法提交了一个异步任务,该任务会返回一个字符串"Hello, World!"。然后,我们使用Future的get方法获取异步计算的结果,并将其打印出来。最后,我们关闭了ExecutorService以释放资源。这个示例演示了如何使用Java Future来执行异步计算并获取结果。

在这里插入图片描述

CompletableFuture应用步骤

在项目中使用CompletableFuture,可以按照以下步骤进行:

  1. 导入CompletableFuture类:首先,需要在项目中导入CompletableFuture类,以便使用其功能。
  2. 创建异步任务:使用CompletableFuture的静态方法supplyAsync或runAsync来创建异步任务。supplyAsync方法接受一个Supplier接口的实现类作为参数,用于定义异步任务的逻辑。runAsync方法接受一个Runnable接口的实现类作为参数,用于定义异步任务的逻辑。
  3. 链式操作:使用CompletableFuture的thenApply、thenAccept、thenRun等方法来链式操作异步任务。这些方法接受一个Function、Consumer或Runnable接口的实现类作为参数,用于定义链式操作的逻辑。
  4. 异常处理:使用CompletableFuture的exceptionally方法来处理异步任务中抛出的异常。exceptionally方法接受一个Function接口的实现类作为参数,用于定义异常处理的逻辑。
  5. 获取结果:使用CompletableFuture的get方法来获取异步计算的结果。get方法会阻塞当前线程,直到异步计算完成并返回结果。

以下是一个简单的示例代码,演示了如何在项目中使用CompletableFuture:

import java.util.concurrent.CompletableFuture;
import java.util.concurrent.ExecutionException;public class CompletableFutureExample {public static void main(String[] args) throws ExecutionException, InterruptedException {CompletableFuture<String> future = CompletableFuture.supplyAsync(() -> {// 模拟耗时操作try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}return "Hello, World!";}).thenApply(result -> {// 链式操作:对结果进行处理return result.toUpperCase();}).thenAccept(result -> {// 链式操作:对结果进行处理并输出到控制台System.out.println(result);});// 获取异步计算的结果(如果需要)future.get();}
}

在上面的示例中,我们首先使用CompletableFuture的supplyAsync方法创建了一个异步任务,该任务会返回一个字符串"Hello, World!"。然后,我们使用thenApply方法对结果进行链式操作,将结果转换为大写字母。接着,我们使用thenAccept方法对结果进行链式操作,将结果输出到控制台。最后,我们使用get方法获取异步计算的结果(如果需要)。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/232683.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

css实现边框彩虹跑马灯效果

效果展示 代码实战 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" content"widthdevice-…

台湾虾皮卖什么比较好

虾皮&#xff08;Shopee&#xff09;平台在台湾地区广受欢迎&#xff0c;吸引了大量的消费者和卖家。该平台上有许多热销产品类别&#xff0c;这些产品在台湾市场上具有巨大的销售潜力。在本文中&#xff0c;我们将介绍虾皮平台上一些热门的产品类别&#xff0c;并提供一些建议…

大数据Doris(三十八):Aggregate 和 Uniq 模型中的 ROLLUP

文章目录 Aggregate 和 Uniq 模型中的 ROLLUP 一、获得每个用户的总消费

〖大前端 - 基础入门三大核心之JS篇(57)〗- 继承

说明&#xff1a;该文属于 大前端全栈架构白宝书专栏&#xff0c;目前阶段免费&#xff0c;如需要项目实战或者是体系化资源&#xff0c;文末名片加V&#xff01;作者&#xff1a;哈哥撩编程&#xff0c;十余年工作经验, 从事过全栈研发、产品经理等工作&#xff0c;目前在公司…

FTP连接报530错误 Permission denied 解决方案

文章目录 1.检查vsftpd状态2.检查配置文件 1.检查vsftpd状态 service vsftpd status图中是已经启动的状态&#xff0c;如果没有启动&#xff0c;输入以下命令之一启动&#xff1a; service vsftpd start service vsftpd restart如果没安装vsftpd&#xff0c;请先安装&#xf…

自助式可视化开发,ETLCloud的集成之路

自助式可视化开发 自助式可视化开发是指利用可视化工具和平台&#xff0c;使非技术人员能够自主创建、定制和部署数据分析和应用程序的过程。 传统上&#xff0c;数据分析和应用程序开发需要专业的编程和开发技能。但是&#xff0c;自助式可视化开发工具的出现&#xff0c;使…

HTML有哪些列表以及具体的使用!!!

文章目录 一、HTML列表二、列表的应用1、无序列表2、有序列表3、自定义列表 三、总结 一、HTML列表 html的列表有三种&#xff0c;一种是无序列表&#xff0c;一种是有序列表&#xff0c;还有一种为自定义列表。 二、列表的应用 1、无序列表 <ul> <li>无序列表…

nodejs 使用 ws/socket.io 模块 websocket 即时通讯

源码 koa-mongodb-template ws 模块 下载 npm install ws简单使用 服务端代码 const WebSocket require("ws"); const WebSocketServer WebSocket.WebSocketServer;const wss new WebSocketServer({ port: 8080 });// 监听客户端连接 wss.on("connectio…

【Linux】冯诺依曼体系结构与操作系统及其进程

> 作者简介&#xff1a;დ旧言~&#xff0c;目前大二&#xff0c;现在学习Java&#xff0c;c&#xff0c;c&#xff0c;Python等 > 座右铭&#xff1a;松树千年终是朽&#xff0c;槿花一日自为荣。 > 目标&#xff1a;了解冯诺依曼体系结构与操作系统&#xff0c;掌握…

我为什么从来不给患者方子?

有的患者问&#xff1a;“大夫我给您几百块钱处方费&#xff0c;拿您的方子自己去抓&#xff0c;行吗&#xff1f;” 我笑着回答&#xff1a;“不行的&#xff0c;跟钱没有关系&#xff0c;原因有以下四个。” 【1】 有的患者带方子走后&#xff0c;找抓药的人或者别的中医对…

用bash写脚本

本章主要介绍如何使用bash写脚本。 了解通配符 了解变量 了解返回值和数值运算 数值的对比 判断语句 循环语句 grep的用法是“grep 关键字 file”&#xff0c;意思是从file中过滤出含有关键字的行。 例如&#xff0c;grep root /var/log/messages&#xff0c;意思是从/var/log/…

【工作流Activiti】MyActivit的maven项目

1、Idea新建一个项目MyActivit的maven项目 2、安装插件 在 idea 里面&#xff0c;activiti 的插件叫 actiBPM&#xff0c;在插件库里面把它安装好&#xff0c;重启 idea 就行了。 3、 maven 项目中&#xff0c;并更改 pom.xml。pom 中依赖如下&#xff1a; <?xml version…

Postman使用总结-断言

让 Postman 工具 代替 人工 自动判断 预期结果 和 实际结果 是否一致 断言代码 书写在 Tests 标签页中。 查看断言结果 Test Results 标签页

安防视频云平台/可视化监控云平台EasyCVR获取设备录像失败,该如何解决?

视频云存储/安防监控EasyCVR视频汇聚平台基于云边端智能协同&#xff0c;支持海量视频的轻量化接入与汇聚、转码与处理、全网智能分发、视频集中存储等。GB28181音视频流媒体视频平台EasyCVR拓展性强&#xff0c;视频能力丰富&#xff0c;具体可实现视频监控直播、视频轮播、视…

Ubuntu安装ARM交叉编译器

Ubuntu安装交叉编译器 更新apt # 更新apt sudo apt update安装gcc sudo apt install build-essential查看gcc版本 gcc -v下载交叉编译工具 复制到用户目录 解压 tar -xvf gcc-linaro-5.5.0-2017.10-x86_64_arm-linux-gnueabihf.tar.xz移动到/opt/下 sudo ./gcc-linaro-5.…

14、Kafka 请求是怎么被处理的

Kafka 请求是怎么被处理的 1、处理请求的 2 种常见方案1.1、顺序处理请求1.2、每个请求使用单独线程处理 2、Kafka 是如何处理请求的&#xff1f;3、控制类请求和数据类请求分离 无论是 Kafka 客户端还是 Broker 端&#xff0c;它们之间的交互都是通过 “请求 / 响应” 的方式完…

Home Assistant HAOS版如何安装HACS

环境&#xff1a; Home Assistant 11.2 SSH & Web Terminal 17.0 问题描述&#xff1a; Home Assistant HAOS版如何安装HACS 解决方案&#xff1a; 1.打开WEB 里面的终端输入下面命令 wget -O - https://hacs.vip/get | bash -如果上面的命令执行后卡住不动&#xff…

深度学习模型(目标检测)轻量化压缩算法的挑战与解决方法

深度学习模型&#xff0c;尤其是用于目标检测的模型&#xff0c;是高度复杂的&#xff0c;通常包括数以百万计的参数和复杂的层次结构。虽然模型压缩和轻量化算法允许这些模型在资源受限的设备上部署和运行&#xff0c;但这仍然是一个活跃和具有挑战性的研究领域&#xff0c;包…

R语言生物群落(生态)数据统计分析与绘图丨R语言基础、tidyverse数据清洗、多元统计分析、随机森林模型、回归及混合效应模型、结构方程模型、统计结果作图

R 语言的开源、自由、免费等特点使其广泛应用于生物群落数据统计分析。生物群落数据多样而复杂&#xff0c;涉及众多统计分析方法。本教程以生物群落数据分析中的最常用的统计方法回归和混合效应模型、多元统计分析技术及结构方程等数量分析方法为主线&#xff0c;通过多个来自…

【Java】工业园区高精准UWB定位系统源码

UWB (ULTRA WIDE BAND, UWB) 技术是一种无线载波通讯技术&#xff0c;它不采用正弦载波&#xff0c;而是利用纳秒级的非正弦波窄脉冲传输数据&#xff0c;因此其所占的频谱范围很宽。UWB定位系统依托在移动通信&#xff0c;雷达&#xff0c;微波电路&#xff0c;云计算与大数据…