【发布时间】:2021-04-11 08:12:17
【问题描述】:
在完成我的任务时,我遇到了一个相当奇怪的错误,无法找到为什么我的 HashMap 每次都被清空。
我绝不会为命名分配寻求解决方案,我只需要这个 HashMap 的帮助。
所以我要做的是使用 SAX API 读取 RSS 提要,并将每个匹配项保存到名为“结果”的 HashMap 中。第二个 hashmap 用于存储我正在阅读的当前项目。
public class SAX extends DefaultHandler{
HashMap<Integer, HashMap<Integer,String>> results = new HashMap<Integer, HashMap<Integer, String>>();
HashMap<Integer, String> current_item = new HashMap<Integer,String>();
int flag = 0;
String[] filter = {"Corona"};
String current = "";
int cnt_results, cnt_item = 0;
public static void main(String[]args) throws ParserConfigurationException, SAXException, IOException {
Init of the Sax Stuff here. This is normal stuff.
But i use the SAX Class as a Handler.
}
public void startDocument() {
System.out.println("Started the RSS Feed...");
}
public void endDocument() {
for(int i = 0; i<this.results.size();++i) {
Map<Integer,String> map = this.results.get(i);
for(int i2 = 0; i2<map.size();++i2) {
System.out.println(map.get(i2));
}
}
System.out.println("Seems like we hit the end.");
}
public void startElement(String uri,String localName, String qName, Attributes attributes) throws SAXException {
if(localName == "item") {
flag = 1;
}
}
public void endElement(String uri, String localName, String qName) throws SAXException {
current_item.put(cnt_item, current);
cnt_item++;
// Filters if description contains one of the Keywords
if(localName == "description") {
for(int i = 0; i<filter.length;++i) {
if(current.contains(filter[i])) {
flag = 2;
break;
}
}
}
if(localName == "item") {
if(flag == 2) {
if(this.results.containsValue(current_item)) {
;
}else {
this.results.put(cnt_results, current_item);
cnt_results++;
}
}
flag = 0;
cnt_item = 0;
current_item.clear();
}
}
public void ignorableWhitespace(char[] ch, int start, int length) throws SAXException {
}
public void characters(char[] ch, int start, int length) throws SAXException{
current = new String(ch,start,length);
}
}
然后,阅读器应该检查 RSS 提要并找到每个具有包含过滤词的描述的项目,并将它们保存到结果地图中。
当尝试读取这些保存的结果时,我只是得到空行。
也许这不是表达其含义的最佳方式,所以我只是给了你整个代码。
很高兴您的帮助。谢谢!
【问题讨论】: