Jak połączyć> 1000 plików xml w jeden przy użyciu Java

Próbuję połączyć wiele plików xml w jeden. Udało mi się to zrobić w DOM, ale to rozwiązanie jest ograniczone do kilku plików. Kiedy uruchamiam go na wielu plikach> 1000, otrzymuję błąd java.lang.OutOfMemoryError.

To, co chcę osiągnąć, to gdzie mam następujące pliki

plik 1:

<root>
....
</root>

plik 2:

<root>
......
</root>

plik n:

<root>
....
</root>

w wyniku: wyjście:

<rootSet>
<root>
....
</root>
<root>
....
</root>
<root>
....
</root>
</rootSet>

To jest moja obecna implementacja:

    DocumentBuilderFactory docFactory = DocumentBuilderFactory.newInstance();
    DocumentBuilder docBuilder = docFactory.newDocumentBuilder();
    Document doc = docBuilder.newDocument();
    Element rootSetElement = doc.createElement("rootSet");
    Node rootSetNode = doc.appendChild(rootSetElement);
    Element creationElement = doc.createElement("creationDate");
    rootSetNode.appendChild(creationElement);
    creationElement.setTextContent(dateString); 
    File dir = new File("/tmp/rootFiles");
    String[] files = dir.list();
    if (files == null) {
        System.out.println("No roots to merge!");
    } else {
        Document rootDocument;
            for (int i=0; i<files.length; i++) {
                       File filename = new File(dir+"/"+files[i]);        
               rootDocument = docBuilder.parse(filename);
               Node tempDoc = doc.importNode((Node) Document.getElementsByTagName("root").item(0), true);
               rootSetNode.appendChild(tempDoc);
        }
    }   

Wiele eksperymentowałem z xslt, saksofonem, ale wydaje mi się, że ciągle czegoś brakuje. Każda pomoc byłaby wysoko ceniona