我从服务器收到360K数据,我将其转换为手机上的XML文件。最终文件大约是1.3 Mb。后来,我尝试在我的GT-S5660上读取此文件,此过程运行5(!)小时。虽然它产生了正确的结果,但我想知道是否有办法优化这个过程。我有一个iphone版本,并且该过程在不到5秒的时间内完成。 这是正常行为吗?如果是这样,SQLIte会成为另一种选择吗? 这是我的代码:
FileInputStream fileos;
try {
fileos = openFileInput("TarifsCache" + Constants.VERSION + ".txt");
} catch (FileNotFoundException e) {
return;
}
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db;
try {
db = dbf.newDocumentBuilder();
} catch (ParserConfigurationException e) {
return;
}
Document doc;
try {
doc = db.parse(new InputSource(fileos));
} catch (SAXException e) {
return;
} catch (IOException e) {
return;
}
doc.getDocumentElement().normalize();
for (int i = 0;; i++) {
NodeList nodeList = doc.getElementsByTagName("Cache" + i);
Node node = nodeList.item(0);
if (node == null)
break;
Element fstElmnt = (Element) node;
NodeList nameList = fstElmnt.getElementsByTagName("area_ref");
Element nameElement = (Element) nameList.item(0);
nameList = nameElement.getChildNodes();
tarifread.area_ref = Integer.parseInt(((Node) nameList.item(0))
.getNodeValue());
然后进行大量其他元素检索。
答案 0 :(得分:0)
尝试使用像SAX这样的高级解析器解析器,并且dnt使用STAX作为它在android中不支持。