import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class ExecutorExample {
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();
// 等待所有任务完成
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);
processTask();
System.out.println(Thread.currentThread().getName() + " End.");
}
private void processTask() {
try {
Thread.sleep(2000); // 模拟耗时任务
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
创建线程池:
Executors.newFixedThreadPool(3)
创建了一个固定大小为3的线程池。这意味着最多同时有3个线程在执行任务。提交任务:
executor.execute(worker)
提交任务给线程池。这里我们提交了5个任务,但线程池只有3个线程,因此部分任务会等待空闲线程。关闭线程池:
executor.shutdown()
方法会关闭线程池,不再接受新的任务,但会继续执行已提交的任务。等待所有任务完成:
while (!executor.isTerminated())
等待所有任务完成。isTerminated()
返回 true
表示所有任务都已完成。任务类:
WorkerThread
实现了 Runnable
接口,并重写了 run
方法。每个任务在 run
方法中执行具体的逻辑,这里通过 Thread.sleep(2000)
模拟耗时任务。输出结果:
上一篇:javafx ui库
下一篇:java http post
Laravel PHP 深圳智简公司。版权所有©2023-2043 LaravelPHP 粤ICP备2021048745号-3
Laravel 中文站