Feature并行执行程序
创始人
2024-05-29 21:23:14

前言

有时候,我们执行一段代码,去从A获取数据,再去从B获取数据,而后从C获取数据,三个业务如果按照串行执行,需要的时间是A+B+C的时间。然而三个业务是可以独立执行的,没有前后约束条件。

代码示例

示例

import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;import java.util.concurrent.*;@SpringBootTest
class DemoFeatureApplicationTests {@Testpublic void feature() throws InterruptedException {long s = System.currentTimeMillis();ExecutorService executor = Executors.newCachedThreadPool();final Future futureA = executor.submit(new Callable() {public Double call() {try {Thread.sleep(5000);} catch (InterruptedException e) {e.printStackTrace();}return 1.2;}});final Future futureB = executor.submit(new Callable() {public Double call() {try {Thread.sleep(6000);} catch (InterruptedException e) {e.printStackTrace();}return 1.3;}});final Future futureC = executor.submit(new Callable() {public Double call() {try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}return 1.1;}});try {Double result = futureA.get(10, TimeUnit.SECONDS);Double result2 = futureB.get(10, TimeUnit.SECONDS);Double result3 = futureC.get(10, TimeUnit.SECONDS);System.out.println("计算结果:" + (result + result2 + result3));System.out.println("耗时:" + (System.currentTimeMillis() - s));} catch (Exception e) {e.printStackTrace();}}
}

示例代码分别表示A业务5秒,B业务6秒,C业务1秒,如果串行执行则需要12秒。那么使用Feature串行后,执行后可见,其使用时间6006毫秒,显然各业务并行执行。
在这里插入图片描述

Feature有什么用?

  • 利用Feature可以让充分利用处理器的并发执行能力,提高程序的运行效率。
  • Feature 在所有任务都执行完后,一并get结果。

相关内容

热门资讯

在深化两岸融合发展中走亲走近、... 转自:贵州日报 夏日福建,第十八届海峡论坛如约而至。台湾有关政党代表以及工会、青年、妇女、民间信仰、...
湄潭茶企开足马力 转自:贵州日报 6月11日,遵义市湄潭县越崎茶业有限公司生产车间内,各条制茶生产线高速运转。作为当地...
花式迎端午 12日至13日,“2026澎湃洞江湖”龙舟邀请赛在福州新区(长乐区)洞江湖公园开赛。本次赛事以舟为媒...
优胜者有机会破格晋升高级工 转自:贵州日报 本报讯(记者 杨唯)贵阳贵安2026年职业技能大赛暨贵阳市第五届“筑城工匠杯”职工职...
重庆公积金 小程序月底关停 办... 6月12日,重庆市住房公积金管理中心发布消息,“重庆公积金”小程序将于6月30日18时关停,缴存人可...