java - ExecutorService 未接来电
问题描述
我对 ExecutorService 有疑问,它不会执行所有调用。
public class MainClass {
public static void main(String[] args) throws IOException, InvalidConnection, InterruptedException {
ExecutorService executor = Executors.newCachedThreadPool();
XMLUrlService xmlUrlService = new XMLUrlService();
LinkedBlockingQueue<String> linkedBlockingQueue = xmlUrlService.getAllXMLUrls();
System.out.println(linkedBlockingQueue.size());
for (int i = 0; i < linkedBlockingQueue.size(); i++) {
executor.execute(new XMLParser(linkedBlockingQueue));
}
executor.shutdown();
}
}
XMLUrlService 类返回一个 URL 列表,然后执行连接。
XMLPaser 是一个负责与给定 URL 建立连接的类。
public class XMLParser implements Runnable {
private LinkedBlockingQueue queue;
public XMLParser(LinkedBlockingQueue queue) {
this.queue = queue;
}
public XMLParser(){}
public void getRates(String data) throws IOException, XMLStreamException, InvalidConnection {
URL url = new URL(data);
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
connection.setRequestMethod("GET");
InputStream inputStream = connection.getInputStream();
inputStream.close();
connection.disconnect();
}
public void run() {
try {
String data = (String) queue.take();
getRates(data);
} catch (InterruptedException | IOException ex) {
//Handle exception
} catch (InvalidConnection invalidConnection) {
invalidConnection.printStackTrace();
} catch (XMLStreamException e) {
e.printStackTrace();
}
}
}
我的阻塞队列包含 250 个不同的 url 地址,但 executorservice 执行随机数量的调用(250 只是要测试的随机数量的元素)。我认为当我从队列中取出项目时,我可以省略一些,但我不确定。
解决方案
你应该改变三件事:
您执行任务的方式
您正在以一种非常奇怪的方式执行任务。而不是通过linkedBlockingQueue
,通过String
类似这样:
System.out.println(linkedBlockingQueue.size());
for (int i = 0; i < linkedBlockingQueue.size(); i++) {
String url = linkedBlockingQueue.remove()
executor.execute(new XMLParser(url));
}
处理异常的方式
不要吞下异常 - 最简单的方法是使用 aCallable
而不是获取Future
s 以便您以后可以检查您的任务发生了什么:
ExecutorService executor = Executors.newCachedThreadPool();
LinkedBlockingQueue<String> linkedBlockingQueue = new LinkedBlockingQueue<String>();
System.out.println(linkedBlockingQueue.size());
List<Future<Void>> result = linkedBlockingQueue.stream().map(
url -> executor.submit(new XMLParser(url))
).collect(Collectors.toList());
for (Future<Void> future : result) {
try {
future.get();
} catch (Exception e) {
System.out.println("Something happened:" + e);
}
}
executor.shutdown();
等待执行 关闭执行器后,等待所有任务完成。
executor.shutdown();
executor.awaitTermination(10, TimeUnit.HOURS);
推荐阅读
- memory - Redis - 在插入失败之前监控最大内存?
- highcharts - 当我向下钻取和向上钻取自定义事件(上下文菜单)不起作用时,highchart 自定义菜单
- iframe - 3D 安全认证 iframe 高度
- c# - 使用表达式树通过C#在分组后生成带有总和的选择语句
- node.js - 我在哪里可以在我的谷歌云服务器中创建文件夹“上传”来存储上传的文件?
- php - 根据 SQL 数据库中的日期可用性更改课程的日历
- python - 将多个工作表从 excel 附加到 pandas 数据框 - 排序问题
- arrays - 从数组中合并 Excel 中的单元格
- python - 模拟 __call__ 属性不会模拟函数
- python - 如何处理“请求太大,API 无法列出”错误?