请问java线程池如何实现并发请求接口?
网友回复
使用 Java 线程池实现并发请求接口,可以有效地管理线程资源,提高系统的吞吐量和响应速度。以下是实现步骤和代码示例:
1. 创建线程池
可以使用 java.util.concurrent.Executors 类提供的工厂方法创建不同类型的线程池,例如固定大小的线程池、缓存线程池等。
// 创建固定大小为 10 的线程池 ExecutorService threadPool = Executors.newFixedThreadPool(10); // 创建缓存线程池,最大线程数为 Integer.MAX_VALUE ExecutorService cachedThreadPool = Executors.newCachedThreadPool();
2. 定义请求任务
将每个请求封装成一个 Runnable 或 Callable 任务,在任务的 run() 或 call() 方法中实现具体的请求逻辑。
class RequestTask implements Callable<String> {
private String url;
public RequestTask(String url) {
this.url = url;
}
@Override
public String call() throws Exception {
// 模拟发送 HTTP 请求并获取响应
URL obj = new URL(url);
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");
int responseCode = con.getResponseCode();
return "Response Code : " + responseCode;
}
} 3. 提交请求任务
调用线程池的 execute() 或 submit() 方法将请求任务提交到线程池。execute() 方法用于 Runnable 任务,submit() 方法用于 Callable 任务并返回 Future 对象,可以通过 Future 对象获取任务执行结果。
// 提交请求任务
List<Future<String>> futures = new ArrayList<>();
for (String url : urls) {
RequestTa...点击查看剩余70%


