面试题答案
一键面试默认线程池工作原理
在Java中,CompletableFuture
默认使用的线程池是ForkJoinPool.commonPool()
。这个线程池是一个共享的线程池,其线程数量默认是CPU核心数 - 1(除非通过系统属性java.util.concurrent.ForkJoinPool.common.parallelism
来设置不同的值)。它使用工作窃取算法,允许空闲线程从忙碌线程的任务队列中窃取任务来执行,以此提高系统资源的利用率,特别是在处理大量小任务时能有效减少线程竞争,提升整体性能。
代码示例
import java.util.concurrent.CompletableFuture;
public class CompletableFutureDefaultThreadPoolExample {
public static void main(String[] args) {
CompletableFuture.supplyAsync(() -> {
// 模拟异步任务
System.out.println("异步任务在默认线程池的线程中执行: " + Thread.currentThread().getName());
return "任务执行结果";
}).thenAccept(result -> {
System.out.println("处理异步任务结果: " + result);
});
// 防止主线程退出,确保异步任务有机会执行
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
在上述代码中,CompletableFuture.supplyAsync
方法使用默认线程池来异步执行提供的Supplier
任务,该任务会打印执行任务的线程名称,并返回一个结果。thenAccept
方法用于处理异步任务的结果。最后通过Thread.sleep
防止主线程退出,确保异步任务能够执行完毕。