ExecutorService是Java中管理异步任务的核心工具,相比直接创建Thread,它通过线程池机制实现线程复用、控制并发数、管理任务队列和统一关闭,提升系统稳定性和资源利用率。

Java中的
ExecutorService
使用
ExecutorService
创建线程池 Java的
Executors
ExecutorService
Executors.newFixedThreadPool(int nThreads)
Executors.newCachedThreadPool()
Executors.newSingleThreadExecutor()
ExecutorService
Executors.newScheduledThreadPool(int corePoolSize)
除了这些工厂方法,我们也可以直接通过
ThreadPoolExecutor
提交任务
ExecutorService
立即学习“Java免费学习笔记(深入)”;
execute(Runnable command)
submit(Callable<T> task)
submit(Runnable task)
Future
Callable
Runnable
submit
Future
关闭线程池 当
ExecutorService
shutdown()
shutdownNow()
import java.util.concurrent.*;
public class ExecutorServiceExample {
public static void main(String[] args) throws InterruptedException, ExecutionException {
// 1. 创建一个固定大小的线程池
ExecutorService executor = Executors.newFixedThreadPool(2);
// 2. 提交Runnable任务
executor.execute(() -> {
System.out.println("Runnable Task 1 running on thread: " + Thread.currentThread().getName());
try {
TimeUnit.SECONDS.sleep(1);
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
}
System.out.println("Runnable Task 1 finished.");
});
// 3. 提交Callable任务并获取Future
Future<String> future = executor.submit(() -> {
System.out.println("Callable Task 2 running on thread: " + Thread.currentThread().getName());
try {
TimeUnit.SECONDS.sleep(2);
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
return "Task 2 interrupted!";
}
System.out.println("Callable Task 2 finished.");
return "Task 2 Result";
});
// 4. 获取Callable任务的结果
System.out.println("Future result: " + future.get()); // get()会阻塞直到任务完成
// 5. 提交更多任务,看它们如何排队
executor.execute(() -> {
System.out.println("Runnable Task 3 running on thread: " + Thread.currentThread().getName());
try {
TimeUnit.SECONDS.sleep(1);
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
}
System.out.println("Runnable Task 3 finished.");
});
// 6. 关闭线程池
executor.shutdown(); // 不再接受新任务,但会等待已提交任务完成
System.out.println("ExecutorService shutdown initiated.");
// 等待所有任务完成,最多等待5秒
if (!executor.awaitTermination(5, TimeUnit.SECONDS)) {
System.err.println("ExecutorService did not terminate in the specified time.");
executor.shutdownNow(); // 尝试立即停止
}
System.out.println("All tasks completed or forcefully stopped.");
}
}这几乎是一个共识了,直接
new Thread()
想象一下,如果你的应用需要处理成千上万个并发请求,每个请求都
new Thread()
OutOfMemoryError
ExecutorService
Runnable
Callable
ExecutorService
ExecutorService
通过线程池,我们可以:
Future
所以,与其说我们“倾向于”使用
ExecutorService
Executors
ThreadPoolExecutor
FixedThreadPool
CachedThreadPool
Integer.MAX_VALUE
SynchronousQueue
CachedThreadPool
SingleThreadExecutor
ScheduledThreadPool
Timer
在实际项目中,很多时候我们最终会发现,
Executors
ThreadPoolExecutor
corePoolSize
maximumPoolSize
keepAliveTime
workQueue
RejectedExecutionHandler
ThreadPoolExecutor
在实际项目中,
ExecutorService
ExecutorService
为什么必须关闭?
ExecutorService
main
优雅关闭的策略
调用shutdown()
shutdown()
最佳实践:在你的应用生命周期结束时(例如,Web应用的
destroy
@PreDestroy
main
shutdown()
配合awaitTermination()
shutdown()
awaitTermination()
awaitTermination(long timeout, TimeUnit unit)
executor.shutdown(); // 启动关闭
try {
// 最多等待60秒,看所有任务是否完成
if (!executor.awaitTermination(60, TimeUnit.SECONDS)) {
// 如果超时了,但任务还没完成,可以考虑强制关闭
executor.shutdownNow();
// 再次等待,给强制关闭一个机会
if (!executor.awaitTermination(60, TimeUnit.SECONDS)) {
System.err.println("线程池未能完全关闭!");
}
}
} catch (InterruptedException ie) {
// 当前线程在等待时被中断,强制关闭
executor.shutdownNow();
Thread.currentThread().interrupt(); // 重新设置中断状态
}这种模式兼顾了优雅和强制,是生产环境中推荐的做法。
使用shutdownNow()
shutdownNow()
适用场景:当系统遇到紧急情况,需要快速释放资源,或者在
awaitTermination()
注意事项:
shutdownNow()
InterruptedException
结合资源管理(try-finally
try-with-resources
ExecutorService
try-finally
ExecutorService executor = Executors.newFixedThreadPool(2);
try {
// 提交任务...
} finally {
executor.shutdown();
// 建议加上awaitTermination()
}对于Java 7+,如果
ExecutorService
AutoCloseable
ExecutorService
try-with-resources
JVM关闭钩子(Shutdown Hook) 对于应用级别的、贯穿整个生命周期的
ExecutorService
final ExecutorService executor = Executors.newFixedThreadPool(5);
// ... 提交任务 ...
Runtime.getRuntime().addShutdownHook(new Thread(() -> {
System.out.println("JVM shutdown hook activated. Shutting down ExecutorService...");
executor.shutdown();
try {
if (!executor.awaitTermination(30, TimeUnit.SECONDS)) {
System.err.println("ExecutorService did not terminate gracefully, forcing shutdown.");
executor.shutdownNow();
}
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
executor.shutdownNow();
}
System.out.println("ExecutorService shutdown complete.");
}));这种方式可以捕获到JVM的正常退出信号(例如,通过Ctrl+C),从而执行清理工作。
总结 正确关闭
ExecutorService
以上就是Java中线程池ExecutorService使用方法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号