客户一线程的例子改写成线程池实现JAVA
时间: 2024-04-02 08:11:04 浏览: 16
下面是一个基于线程池的 Java 代码示例,它是原本单线程的任务处理程序的改进版本:
```java
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class ThreadPoolExample {
public static void main(String[] args) {
ExecutorService executor = Executors.newFixedThreadPool(10); //创建一个固定大小的线程池
for (int i = 0; i < 100; i++) { //提交100个任务
Runnable worker = new WorkerThread("" + i);
executor.execute(worker); //使用线程池执行任务
}
executor.shutdown(); //关闭线程池
while (!executor.isTerminated()) { } //等待所有任务完成
System.out.println("Finished all threads");
}
}
class WorkerThread implements Runnable {
private String message;
public WorkerThread(String s) {
this.message = s;
}
public void run() {
System.out.println(Thread.currentThread().getName() + " (Start) message = " + message);
processMessage(); //执行任务
System.out.println(Thread.currentThread().getName() + " (End)");
}
private void processMessage() {
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
```
在这个示例中,我们使用了 `Executors.newFixedThreadPool()` 方法创建了一个固定大小的线程池,然后使用 `executor.execute(worker)` 方法提交了100个任务。在任务执行完成之后,我们使用 `executor.shutdown()` 方法关闭线程池,并使用 `while (!executor.isTerminated()) { }` 循环等待所有任务完成。最后,我们输出 "Finished all threads" 表示所有任务都已完成。
可以看到,相比于单线程的任务处理程序,使用线程池可以更高效地处理大量的并发任务,提高了程序的性能。