Reputation: 3897
Both of them seem to have the same purpose (create a XMLReader). Some Tutorials contain the one, some the other.
SAXParserFactory:
example code:
// SAXParserFactory
SAXParserFactory factory = SAXParserFactory.newInstance();
SAXParser parser = factory.newSAXParser();
XMLReader reader = parser.getXMLReader();
reader.parse(new InputSource("document.xml"));
XMLReaderFactory:
example code:
// XMLReaderFactory
XMLReader xmlReader = XMLReaderFactory.createXMLReader();
xmlReader.parse(new InputSource("document.xml"));
question:
Are these the main differences or are there some i've overseen.
Which one should you choose?
Upvotes: 9
Views: 9368
Reputation: 163262
Elliotte Rusty Harold, who has written a book on XML processing in Java, once wrote:
SAXParserFactory [is] a hideous, evil monstrosity of a class that should
be hung, shot, beheaded, drawn and quartered, burned at the stake,
buried in unconsecrated ground, dug up, cremated, and the ashes tossed
in the Tiber while the complete cast of Wicked sings "Ding dong, the
witch is dead." --Elliotte Rusty Harold on xml-dev
I wouldn't actually go that far (and if I did, I would try and make it grammatical). Like a lot of JAXP, it's not the most wonderful piece of design; but I do use it as the default way of getting a parser instance, if only because it's consistent with other parts of JAXP.
Historically, the two were developed in parallel. JAXP originally tried to add missing functionality to SAX1, but in parallel, SAX2 was coming along and filled in some of the gaps, so this particular gap got filled twice.
Upvotes: 3
Reputation: 5603
The main JAXP APIs
are defined in the javax.xml.parsers
package. That package contains vendor-neutral factory classes like the SAXParserFactory
which give you a SAXParser
.
The SAXParserFactory
defines a factory API that enables applications to configure and obtain a SAX based parser to parse XML documents.
The SAXParser
defines the API that wraps an XMLReader
implementation class.
The Package org.xml.sax
defines the basic SAX APIs.
The Java Runtime comes with a default implementation XMLReader
The SAXParserFactory
hides details of which (SAX1) ParserFactory / (SAX2) XMLReaderFactory, ... from you.
If you want to be able to replace the default JAXP
Parser by a different JAXP
Parser (there may be a known incomapatibilty / bug in the default implementation) implementation you should use the vendor neutral SAXParserFactory
.
If you know that your application will allways use a SAX2
XMLReader
you may use the XMLReaderFactory
.
Upvotes: 4