线程池threadpool怎么使用
时间: 2023-09-21 07:09:54 浏览: 55
以下是引用中的代码示例:
```java
ExecutorService executor = Executors.newFixedThreadPool(2);
Runnable worker = new Runnable() {
public void run() {
// do some work
}
};
executor.execute(worker);
```
这段代码创建了一个固定大小的线程池,其中corePoolSize为2,maximumPoolSize也为2。这意味着线程池最多会保持2个线程处于活动状态,并在任务到达时创建新的线程来处理任务。当队列中没有任务时,线程池中的线程会进入空闲状态,直到有新的任务到来。如果使用的是无界队列(例如LinkedBlockingQueue),那么线程数就不会超过corePoolSize。keepAliveTime参数指定了线程池中的空闲线程在等待新任务时的存活时间。
以下是引用中的代码示例:
```java
ExecutorService executor = Executors.newFixedThreadPool(5);
Runnable worker = new Runnable() {
public void run() {
// do some work
}
};
executor.execute(worker);
```
这段代码创建了一个固定大小的线程池,其中corePoolSize为5,maximumPoolSize也为5。这意味着线程池最多会保持5个线程处于活动状态,并在任务到达时创建新的线程来处理任务。当队列中没有任务时,线程池中的线程会进入空闲状态,直到有新的任务到来。如果使用的是无界队列(例如LinkedBlockingQueue),那么线程数就不会超过corePoolSize。keepAliveTime参数指定了线程池中的空闲线程在等待新任务时的存活时间。这段代码创建了一个5个线程的线程池,如果需要创建更多的线程,可以调整corePoolSize和maximumPoolSize的值。如果使用的是有界队列(例如ArrayBlockingQueue),那么可以通过调用put()方法将任务放入队列中。这段代码展示了如何创建一个固定大小的线程池,并使用execute()方法执行任务。如果需要停止线程池,可以使用shutdown()方法或者shutdownNow()方法。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* *3* [线程池ThreadPool详解](https://blog.csdn.net/qq_43651945/article/details/124717896)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 100%"]
[ .reference_list ]