Я анализирую XML-документ в своей собственной структуре, но создание его очень медленно для больших входных данных, есть ли лучший способ сделать это?
public static DomTree<String> createTreeInstance(String path)
throws ParserConfigurationException, SAXException, IOException {
DocumentBuilderFactory docBuilderFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder db = docBuilderFactory.newDocumentBuilder();
File f = new File(path);
Document doc = db.parse(f);
Node node = doc.getDocumentElement();
DomTree<String> tree = new DomTree<String>(node);
return tree;
}
Вот мой конструктор DomTree:
/**
* Recursively builds a tree structure from a DOM object.
* @param root
*/
public DomTree(Node root){
node = root;
NodeList children = root.getChildNodes();
DomTree<String> child = null;
for(int i = 0; i < children.getLength(); i++){
child = new DomTree<String>(children.item(i));
if (children.item(i).getNodeType() != Node.TEXT_NODE){
super.children.add(child);
}
}
}
UPDATE:
Я протестировал метод createTreeInstance (), используя XML-файл размером 100 МБ:
- Создание docBuilderFactory ... Готово [3 мс]
- Создание docBuilder ... Готово [21 мс]
- файл разбора ... Готово [5646ms]
- getDocumentElement ... Готово [1 мс]
- создание DomTree ... Готово [17076ms]
UPDATE:
Как предлагает Джон Доу ниже, может быть более целесообразно использовать SAX - я никогда раньше не использовал SAX, поэтому есть ли хороший способ конвертировать то, что я должен, используя SAX?