我有一个8兆文件.使用JAXB编组需要1082ms,使用DOM需要862ms,使用SAX需要438ms.这是使用JDK 1.6的所有默认值,不使用额外的配置,如使用woodstox.
为了从JAXB获得更好的性能,我尝试使用SAX解析来做…
FileReader fr = new FileReader("myfile.xml"); JAXBContext jc = JAXBContext.newInstance(MyObjectList.class); Unmarshaller unmarshaller = jc.createUnmarshaller(); XMLInputFactory xmlif = XMLInputFactory.newInstance(); XMLEventReader xmler = xmlif.createXMLEventReader(fr); long beginTime = System.currentTimeMillis(); MyObjectList obj = (MyObjectList)unmarshaller.unmarshal(xmler); long endTime = System.currentTimeMillis();
这让它走得更慢 – 3207ms.
我的问题是:
1.如何让JAXB走得更快?
2.如何100%确定它使用的底层解析机制?
1 – How do I make JAXB go faster?
您正在从StAX输入中解开正确的轨道,但我会推荐一个XMLStreamReader而不是XMLEventReader.
XMLInputFactory xmlif = XMLInputFactory.newInstance(); XMLStreamReader xmler = xmlif.createXMLStreamReader(fr);
由于StAX是一个标准,您可以将另一个实现(如WoodStox)切换为底层解析器.
2 – How can I be 100% sure what underlying parsing mechanism it is using?
就像你在做.如果您将JAXB实现传递给XMLStreamReader的实例,那么您可以确定它正在被使用.另一方面,如果您从InputStream类似的方式解组,则JAXB实现可以自由使用任何需要的解析技术.如果您与Woodstox一起去,请务必查看性能页面: