Java threadpoolexecutor使用例子
时间: 2023-09-21 11:11:41 浏览: 122
Java中的ThreadPoolExecutor是一个线程池的实现类,它提供了一种方便的方式来管理和重用线程。下面是一个ThreadPoolExecutor的使用例子:
```java
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.ThreadPoolExecutor;
public class ThreadPoolExecutorExample {
public static void main(String[] args) {
// 创建一个线程池,包含10个线程
ExecutorService executorService = Executors.newFixedThreadPool(10);
// 将线程池强制转换为ThreadPoolExecutor类型
ThreadPoolExecutor threadPoolExecutor = (ThreadPoolExecutor) executorService;
// 设置线程池的属性
threadPoolExecutor.setCorePoolSize(5);
threadPoolExecutor.setMaximumPoolSize(10);
threadPoolExecutor.setKeepAliveTime(5000, TimeUnit.MILLISECONDS);
// 执行任务
for (int i = 0; i < 20; i++) {
executorService.execute(new Task(i));
}
// 关闭线程池
executorService.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.");
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("Task " + taskId + " is completed.");
}
}
}
```
在上面的例子中,我们创建了一个包含10个线程的线程池,然后将其强制转换为ThreadPoolExecutor类型,并设置了线程池的属性。接着,我们执行了20个任务,每个任务都是一个Runnable对象,最后关闭了线程池。
注意,我们可以通过调用execute方法来提交任务到线程池中,而不需要手动创建线程。线程池会自动管理和重用线程,可以更加高效地利用系统资源。
阅读全文