1. 前言
最近在看Java8中对并发的支持CompletableFuture类,觉得挺好的,在单一线程执行的时候可以省略很多代码,手动验证后,发现其中还是有一部分坑的,此处记录一下。此处主要描述其创建线程为守护线程的问题,会随着主线程消亡直接消亡,导致任务失败。
2. CompletableFuture优点
简洁,后面以代码为例
3. 案例简述
3.1 CompletableFuture创建一个线程,内部进行轮询读取任务(如:模拟kafka之类的),会发现,执行结束后,整个线程一起关闭了,无法打到一直轮询的目的。传统直接创建的线程(默认为非守护线程)会由于子线程未结束,阻止主线程关闭。
4. 代码
package com.hz.threadpool.thread;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.TimeUnit;
/**
* @description:
* @author: pp_lan
* @date: 2022/3/24
*/
public class CompletableFutureTest {
/**
* java8并发接口
*/
public static void main(String[] args) throws InterruptedException {
System.out.println("============== testAsyncRunnable ===============");
CompletableFuture.runAsync((() -> {
while (true) {

本文探讨了Java8中CompletableFuture在并发处理时的一个问题,即默认使用ForkJoinPool线程池创建的线程是守护线程,可能导致任务在主线程结束后被提前终止。作者通过案例展示了当CompletableFuture用于长时间运行任务时,由于守护线程特性,任务会在主线程退出时被强制停止。为解决此问题,提出了自定义线程池的方式,确保任务能够持续运行。同时,文章分析了源码并提供了详细的解决方案,强调了线程池需手动关闭的重要性。
最低0.47元/天 解锁文章
4008





