用java写一个线程池
时间: 2023-03-07 07:44:35 浏览: 127
我可以给你一些参考资料: 1. Java编程语言中的线程池:https://docs.oracle.com/javase/7/docs/api/java/util/concurrent/ThreadPoolExecutor.html 2. Java 线程池的详细介绍:https://www.journaldev.com/1069/threadpoolexecutor-java-thread-pool-example-executorservice 3. 使用 Executors 创建线程池:https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/Executors.html
相关问题
用java 写一个线程池
以下是一个简单的 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(5);
// 提交任务到线程池
for (int i = 1; i <= 10; i++) {
Runnable worker = new WorkerThread("Task " + i);
executor.execute(worker);
}
// 关闭线程池
executor.shutdown();
while (!executor.isTerminated()) {
}
System.out.println("All tasks are finished!");
}
}
class WorkerThread implements Runnable {
private String taskName;
public WorkerThread(String taskName) {
this.taskName = taskName;
}
@Override
public void run() {
System.out.println(Thread.currentThread().getName() + " is executing " + taskName);
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName() + " has finished " + taskName);
}
}
```
这个例子中,我们使用了 `ExecutorService` 接口和 `Executors` 类来创建一个具有固定线程数量的线程池。然后,我们提交了一系列任务到线程池中,每个任务都是一个实现了 `Runnable` 接口的工作线程。线程池会自动分配线程来执行这些任务,并在所有任务都执行完毕后关闭线程池。
用JAVA写一个线程池
在 Java 中,你可以使用 Executor 框架来创建线程池。
要创建线程池,你需要使用 Executors 类的静态工厂方法之一来创建 ExecutorService 对象,如 newFixedThreadPool() 或 newCachedThreadPool()。
例如,你可以使用以下代码创建固定大小的线程池:
```
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
// 创建固定大小的线程池
ExecutorService threadPool = Executors.newFixedThreadPool(10);
```
然后,你可以使用 ExecutorService 的 execute() 方法来将 Runnable 对象提交到线程池进行执行。
例如:
```
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
ExecutorService threadPool = Executors.newFixedThreadPool(10);
threadPool.execute(new Runnable() {
@Override
public void run() {
// 这里写你的任务代码
}
});
```
你还可以使用 ExecutorService 的 submit() 方法来提交 Callable 对象,这样你就可以在任务完成后获取返回值。
例如:
```
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
ExecutorService threadPool = Executors.newFixedThreadPool(10);
Future<String> future = threadPool.submit(new Callable<String>() {
@Override
public String call() throws Exception {
// 这里写你的任务代码
return "Task completed!";
}
});
// 获取任务的返回值
String result = future.get();
```
在线程池不再需要的时候,你应该使用 ExecutorService 的 shutdown() 方法关闭它,这样
阅读全文