Java多线程池的实现方法通常是使用java.util.concurrent包中的Executor框架。具体来说,可以使用ExecutorService接口来创建和管理线程池,常用的实现类是ThreadPoolExecutor。
以下是使用ThreadPoolExecutor创建线程池的示例代码:
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);
// 提交任务给线程池
for (int i = 0; i < 10; i++) {
executor.execute(new Task(i));
}
// 关闭线程池
executor.shutdown();
}
static class Task implements Runnable {
private int taskId;
public Task(int taskId) {
this.taskId = taskId;
}
@Override
public void run() {
System.out.println("Task " + taskId + " is running in thread " + Thread.currentThread().getName());
}
}
}
在上面的示例中,首先通过Executors工厂类创建了一个固定大小为3的线程池,然后通过executor.execute方法提交了10个任务给线程池。每个任务都是一个实现了Runnable接口的Task类,其中的run方法定义了任务的具体执行逻辑。最后通过executor.shutdown方法关闭线程池。