Java——SAX解析XML文件

本文介绍了使用SAX解析XML文件的方法,与DOM解析的区别在于SAX不会将XML全部加载到内存,而是逐个节点解析。详细步骤包括:获取SAXParserFactory和SAXParser实例,创建继承DefaultHandler的自定义Handler,重写startDocument、endDocument、startElement、endElement等方法,以及如何处理节点内容。最后通过ParseUtil类调用parse方法实现解析。
摘要由CSDN通过智能技术生成

上一篇文章使用了DOM解析XML文件,本篇文章将使用SAX解析XML。

DOM与SAX解析的不同之处在于:DOM解析会将XML全部加载到内存中,再进行解析;而SAX解析有一个Handler,该Handler将对每个节点逐个进行解析。


SAX解析的步骤:

  1. 通过SAXParserFactory的静态方法newInstance()获取SAXParserFactory的实例。
  2. 通过SAXParserFactory实例的newSAXParser()方法获取SAXParser的实例。
  3. 创建一个类,继承DefaultHandler,并重写startElement()方法(用来遍历xml的开始节点)、endElement()方法(用来遍历xml的结束节点)、startDocument()方法(用来标志解析开始)、endDocument()方法(用来标志解析结束)

这里使用的XML文件和Book类与DOM解析时的完全相同,这里就不再赘述,直接给出代码:

books.xml:

<?xml version="1.0" encoding="UTF-8"?>
<bookstore>
    <book id="1">
        <name>冰与火之歌</name>
        <author>乔治马丁</author>
        <price>89</price>
    </book>
    <book id="2">
        <name>安徒生童话</name>
        <author>安徒生</author>
        <price>24</price>
    </book>
</bookstore>

Book.java:

package domain;

public class Book {
   
    private int id;
    private String name;
    private String author;
    private float price;

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值