import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class ThreadPoolExample {
public static void main(String[] args) {
// 创建一个固定大小的线程池,大小为5
ExecutorService executorService = Executors.newFixedThreadPool(5);
// 提交10个任务给线程池执行
for (int i = 0; i < 10; i++) {
Runnable worker = new WorkerThread("Task " + i);
executorService.execute(worker);
}
// 关闭线程池
executorService.shutdown();
while (!executorService.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(5)
创建了一个固定大小为5的线程池。这意味着最多同时有5个线程在执行任务。executorService.execute(worker)
提交了10个任务给线程池。每个任务都是一个实现了 Runnable
接口的 WorkerThread
对象。executorService.shutdown()
方法来关闭线程池,表示不再接受新的任务。然后通过 isTerminated()
方法等待所有任务完成。WorkerThread
实例在 run()
方法中模拟了一个耗时2秒的任务,并打印出当前线程的信息。这样可以有效地管理和复用线程资源,避免频繁创建和销毁线程带来的性能开销。
上一篇:java boolean
下一篇:java图片压缩
Laravel PHP 深圳智简公司。版权所有©2023-2043 LaravelPHP 粤ICP备2021048745号-3
Laravel 中文站