getChildNodes geben unerwartetes Ergebnis

Meine XML sieht wie folgt aus-

<collected_objects>
        <object flag="complete" id="objId" version="1">
          <variable_value variable_id="varId">ValueGoesHere</variable_value>
          <reference item_ref="2"/>
        </object>
        <object comment="objComment" flag="complete" id="objId" version="1">
          <reference item_ref="1"/>
        </object>
</collected_objects>

Ich bin Verarbeitung ist es mit folgenden code-

Document dom = parser.getDocument();
    NodeList collected_objects = dom.getElementsByTagName("object");
    System.out.println("Number of collected objects are " + collected_objects.getLength());

        for (int i = 0; i < collected_objects.getLength(); i++) {

            Node aNode = collected_objects.item(i);
            //get children of "objects"         
            NodeList refNodes = aNode.getChildNodes();

            System.out.println("# of chidren are " + refNodes.getLength());

            //print attributes of "objects"

            NamedNodeMap attributes = aNode.getAttributes();
            for (int a = 0; a < attributes.getLength(); a++) {
             Node theAttribute = attributes.item(a);
             System.out.println(theAttribute.getNodeName() + "=" + theAttribute.getNodeValue());

        }

}

gibt es als-

Number of collected objects are 2
# of chidren are 5
flag=complete
id=objId
version=1
# of chidren are 3
comment=objComment
flag=complete
id=objId
version=1

Meine Frage ist, warum "# chidren" sind 5 und 3 jeweils? Darf ich nicht erwartet, 2 und 1 jeweils ?
denn erstes Ziel "variable_value" und "reference" und das zweite Objekt nur "reference"

Im wesentlichen, meine Absicht ist es, Prozess Kinder "Objekte".

InformationsquelleAutor user837208 | 2011-12-19

Schreibe einen Kommentar