import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class ThreadPoolExample {
public static void main(String[] args) {
// 创建一个固定大小的线程池,这里设置为3个线程
ExecutorService executor = Executors.newFixedThreadPool(3);
// 提交5个任务给线程池执行
for (int i = 0; i < 5; i++) {
Runnable worker = new WorkerThread("Task " + i);
executor.execute(worker);
}
// 关闭线程池,不再接受新的任务,但会继续执行已提交的任务
executor.shutdown();
// 可以调用isTerminated()方法检查线程池是否已经关闭完成
while (!executor.isTerminated()) {
// 等待所有任务完成
}
System.out.println("Finished all threads");
}
}
class WorkerThread implements Runnable {
private String task;
public WorkerThread(String s) {
this.task = s;
}
@Override
public void run() {
System.out.println(Thread.currentThread().getName() + " Start. Task = " + task);
try {
Thread.sleep(2000); // 模拟任务执行时间
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName() + " End. Task = " + task);
}
}
Executors.newFixedThreadPool(3)
创建了一个固定大小为3的线程池。executor.execute(worker)
提交了5个任务给线程池执行。每个任务都是一个实现了 Runnable
接口的 WorkerThread
实例。executor.shutdown()
方法来关闭线程池,表示不再接受新的任务,但会继续执行已提交的任务。while (!executor.isTerminated())
循环等待所有任务完成。WorkerThread
的 run()
方法中模拟了一个简单的任务执行过程,并打印出任务开始和结束的信息。这个示例展示了如何使用 Java 的线程池来管理多个任务的并发执行。
上一篇:java反射
下一篇:java获取符号包裹的字符串
Laravel PHP 深圳智简公司。版权所有©2023-2043 LaravelPHP 粤ICP备2021048745号-3
Laravel 中文站