当前位置: 首页 > wzjs >正文

小吃网站建设做seo推广公司

小吃网站建设,做seo推广公司,wordpress 订单插件,工信部网站验证码一、CompletableFuture简介 CompletableFuture是Java 8引入的一个类,用于异步编程,它提供了强大的功能来帮助开发者实现非阻塞式的编程,支持函数式风格,并能有效避免回调地狱(Callback Hell)。 核心优势&…

一、CompletableFuture简介

CompletableFuture是Java 8引入的一个类,用于异步编程,它提供了强大的功能来帮助开发者实现非阻塞式的编程,支持函数式风格,并能有效避免回调地狱(Callback Hell)。

核心优势:

  • 异步非阻塞:任务可在独立线程中异步执行,不影响主线程。
  • 链式调用:支持函数式编程,方便链式处理。
  • 组合与聚合:能简单地将多个异步任务结果组合。
  • 异常处理:可对异步任务中的异常灵活处理。

二、CompletableFuture创建方式

方式一:手动创建

CompletableFuture<String> future = new CompletableFuture<>();
future.complete("success"); // 手动设置结果

方式二:使用runAsync(无返回值)

CompletableFuture<Void> future = CompletableFuture.runAsync(() -> {System.out.println("异步任务,无返回值");
});

方式三:使用supplyAsync(有返回值)

CompletableFuture<String> future = CompletableFuture.supplyAsync(() -> {return "异步任务,有返回值";
});
  • runAsyncsupplyAsync方法默认使用公共线程池(ForkJoinPool.commonPool())。
  • 也可指定自定义线程池:
ExecutorService executor = Executors.newFixedThreadPool(10);
CompletableFuture<String> future = CompletableFuture.supplyAsync(() -> {return "使用自定义线程池";
}, executor);

三、获取异步结果

阻塞式获取:

CompletableFuture<String> future = CompletableFuture.supplyAsync(() -> "result");
String result = future.get(); // 会阻塞线程,等待任务执行完毕

非阻塞式获取(推荐):

CompletableFuture<String> future = CompletableFuture.supplyAsync(() -> "result");
future.thenAccept(result -> {System.out.println("任务执行完成: " + result);
});

四、CompletableFuture常用方法及用法示例

4.1 链式调用(thenApply、thenAccept、thenRun)

  • thenApply(上一步结果作为入参,返回一个新的结果):
CompletableFuture<Integer> future = CompletableFuture.supplyAsync(() -> 5).thenApply(i -> i * 10); // 结果为50
  • thenAccept(消费结果,无返回值):
CompletableFuture.supplyAsync(() -> "Hello").thenAccept(System.out::println); // 输出:Hello
  • thenRun(不关心上一步结果,无返回值):
CompletableFuture.supplyAsync(() -> "Hello").thenRun(() -> System.out.println("任务完成"));

4.2 异常处理(exceptionally、handle)

  • exceptionally:捕获异常并提供默认值:
CompletableFuture<Integer> future = CompletableFuture.supplyAsync(() -> {return 1 / 0; // 模拟异常
}).exceptionally(e -> {System.out.println("异常: " + e);return -1; // 默认值
});
  • handle:处理结果或异常:
CompletableFuture<Integer> future = CompletableFuture.supplyAsync(() -> {return 1 / 0; // 模拟异常
}).handle((res, ex) -> {if (ex != null) {System.out.println("异常:" + ex);return -1;}return res;
});

4.3 组合多个CompletableFuture任务

thenCompose(任务串行化)
  • 将两个有依赖关系的异步任务串联:
CompletableFuture<Integer> future = CompletableFuture.supplyAsync(() -> 10).thenCompose(i -> CompletableFuture.supplyAsync(() -> i + 1)); // 输出11
thenCombine(任务并行组合)
  • 两个任务并行执行,结果合并:
CompletableFuture<Integer> future1 = CompletableFuture.supplyAsync(() -> 10);
CompletableFuture<Integer> future2 = CompletableFuture.supplyAsync(() -> 20);CompletableFuture<Integer> combined = future1.thenCombine(future2, (r1, r2) -> r1 + r2);
// combined结果为30

4.4 多个CompletableFuture并发控制

allOf(等待所有任务完成)
CompletableFuture<String> f1 = CompletableFuture.supplyAsync(() -> "A");
CompletableFuture<String> f2 = CompletableFuture.supplyAsync(() -> "B");CompletableFuture<Void> all = CompletableFuture.allOf(f1, f2);
all.thenRun(() -> {System.out.println("所有任务执行完毕");
});
anyOf(任意任务完成)
CompletableFuture<String> f1 = CompletableFuture.supplyAsync(() -> {Thread.sleep(500);return "任务1";
});
CompletableFuture<String> f2 = CompletableFuture.supplyAsync(() -> {Thread.sleep(100);return "任务2";
});CompletableFuture<Object> any = CompletableFuture.anyOf(f1, f2);
any.thenAccept(result -> {System.out.println("第一个完成的任务结果:" + result);
});

五、常见应用场景

  • 提高系统吞吐量(非阻塞式的业务流程)
  • 并发调用多个API、远程服务以提升响应速度
  • 更优雅地处理异步回调逻辑,减少代码耦合

示例:并发获取数据并聚合

CompletableFuture<String> futureUser = CompletableFuture.supplyAsync(() -> getUser());
CompletableFuture<String> futureOrder = CompletableFuture.supplyAsync(() -> getOrder());CompletableFuture<String> combined = futureUser.thenCombine(futureOrder, (user, order) -> {return user + "的订单是:" + order;
});combined.thenAccept(System.out::println);

六、最佳实践与注意事项

  • 避免使用get()方法,推荐使用回调方式(如thenAccept、thenApply等);
  • 使用自定义线程池以避免线程池资源竞争,尤其在高并发场景;
  • 合理使用异常处理机制,避免漏掉异步任务异常导致业务流程不正确。

七、总结与推荐

CompletableFuture是现代Java编程不可缺少的利器,熟练使用它能极大提升代码的并发性能、响应效率和优雅性。尤其在高并发、微服务、异步调用等场景中,熟悉并掌握CompletableFuture至关重要。

http://www.dtcms.com/wzjs/228417.html

相关文章:

  • 电子商务网站建站目的推广资源网
  • 潍坊网站设计制作网站推广网络营销
  • 手机网站制作与建设营销策划方案内容
  • 微信官网免费下载安装西安企业seo外包服务公司
  • 安徽网站建设公司网站链接交易
  • 濮阳做网站星月网络网站开发语言
  • 手机怎样做网站百度广告服务商
  • 如何网站数据备份广州最近爆发什么病毒
  • 百度收录了我新网站的2篇文章了杭州排名优化公司
  • 哪里有服务好的网站建设公司整站seo优化哪家好
  • 上海招标网简单网站建设优化推广
  • 秦皇岛公司做网站友情链接平台网站
  • 酒店品牌策划方案台州优化排名推广
  • 网站建设做网站费用百度搜索一下百度
  • 单仁资讯做网站怎样网站seo主要是做什么的
  • 专业公司网站建设服务公司管理培训
  • 鲜花品牌网站建设广州网站推广
  • 线上做笔记的网站百度热线人工服务电话
  • 昆山高端网站建设咨询成人计算机速成培训班
  • 企业网络推广如何做seo推广排名平台有哪些
  • wordpress酷站企业文化的重要性
  • 做批发的有哪些网站小程序定制开发
  • wordpress切换主题出现白屏seo优化中商品权重主要由什么决定
  • 西安单位网站制作2024年瘟疫大爆发
  • 传媒公司怎么套路新人搜索引擎优化面对哪些困境
  • 在线制作视频seo 资料包怎么获得
  • 做外贸网站用哪些小语种网级移动营销app下载
  • 石家庄城乡建设网站seo优化一般包括哪些内容()
  • 做宣传页的网站seo优化方案项目策划书
  • 长沙最好网站建设谷歌seo 优化