我写了一个工作正常的 n 叉树 ADT。但是,我需要将其序列化存储在调用类的变量中。例如。
DomTree<String> a = Data.createTreeInstance("very_large_file.xml");
String x = a.toString();
我已经编写了完全符合我需要的目的的方法,但是在非常大的输入上它需要很长时间(100MB xml 文件需要 20 分钟) - 我已经为这些方法计时并且从 xml 文件构建树很快,但是调用上图的 toString() 非常慢。
@Override
public String toString(){
return printTree(this);
}
public String printTree(AbstractTree<E> tree){
if (tree.isLeaf()){
return tree.getNodeName();
}else{
String tStr = tree.getNodeName() + "(";
int i = 0;
Iterator<AbstractTree<E>> child = tree.getChildren().iterator();
while (i < tree.getChildren().size() - 1){
tStr += printTree(child.next()) + ", ";
i++;
}
tStr += printTree(child.next()) + ")";
return tStr;
}
}
我猜这与字符串的构建方式有关,而不是与树的遍历方式有关?有一个更好的方法吗?
更新:按照 Skaffman 的示例,以下代码针对非常大的输入给出 outOfMemoryError。
@Override
public String toString(){
StringBuilder buffer = new StringBuilder();
printTree(this, buffer);
return buffer.toString();
}
public String printTree(AbstractTree<E> tree, StringBuilder buffer){
if (tree.isLeaf()){
return tree.getNodeName();
}else{
buffer.append(tree.getNodeName());
buffer.append("(");
int i = 0;
Iterator<AbstractTree<E>> child = tree.getChildren().iterator();
while (i < tree.getChildren().size() - 1){
buffer.append(printTree(child.next(), buffer));
buffer.append(", ");
i++;
}
buffer.append(printTree(child.next(), buffer));
buffer.append(")");
return buffer.toString();
}
}
更新:现在完美运行,使用 Skaffmans 示例