久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術文章
文章詳情頁

java - JDK8的CompletableFuture使用問題

瀏覽:121日期:2023-10-31 13:05:02

問題描述

CompletableFuture cf1 = CompletableFuture.supplyAsync(() -> { System.out.println('enter into completableFuture()'); try {TimeUnit.SECONDS.sleep(1); } catch (InterruptedException e) {e.printStackTrace(); } System.out.println('start to out of completableFuture()'); return 'a';});System.out.println('do something else');cf1.thenApply(v -> v + ' b').thenAcceptAsync(v ->System.out.println(v));System.out.println('finalize...');//注釋最后一行,無法得到預期結果//TimeUnit.SECONDS.sleep(10);

得到引結果為:

do something elseenter into completableFuture()finalize...start to out of completableFuture()a b

以上代碼如果注釋掉最后一行,無法得到預期結果。

為什么一定要顯式的讓程序sleep10秒呢?

問題解答

回答1:

見CompletableFuture.supplyAsync的javadoc:

Returns a new CompletableFuture that is asynchronously completed by a task running in the ForkJoinPool.commonPool() with the value obtained by calling the given Supplier.

而ForkJoinPool.commonPool()的javadoc:

Returns the common pool instance. This pool is statically constructed; its run state is unaffected by attempts to shutdown or shutdownNow. However this pool and any ongoing processing are automatically terminated upon program System.exit. Any program that relies on asynchronous task processing to complete before program termination should invoke commonPool().awaitQuiescence, before exit.

如果你把最后的sleep改成ForkJoinPool.commonPool().awaitQuiescence(2, TimeUnit.SECONDS);也能達到你預期結果

回答2:

搜索一下:守護線程當線程中只剩下守護線程時JVM就會退出,反之還有任意一個用戶線程在,JVM都不會退出。我們可以猜測CompletableFuture.supplyAsync啟動了一個守護線程,實際上CompletableFuture內部默認使用ForkJoinPool,該線程池初始化一個線程工廠類:

defaultForkJoinWorkerThreadFactory = new DefaultForkJoinWorkerThreadFactory();

查看他的的實現,每次都是創建守護進程。至于為什么一定要主線程sleep就很好理解。

標簽: java
相關文章:
主站蜘蛛池模板: 宁夏| 南华县| 邹城市| 华池县| 秦安县| 佛学| 始兴县| 宁强县| 会泽县| 咸丰县| 普定县| 南阳市| 多伦县| 成安县| 枣阳市| 阳城县| 华容县| 兰坪| 福州市| 墨江| 宜兰市| 青州市| 洞口县| 隆子县| 安国市| 岢岚县| 集贤县| 松阳县| 长沙县| 兰溪市| 福安市| 淮南市| 乌兰浩特市| 宜宾县| 锦屏县| 余江县| 伊宁县| 临沭县| 景谷| 绥滨县| 都江堰市|