一、理论准备

    SAX采用事件驱动机制来解析XML文档,每当SAX解析器发现文档开始、元素开始、文本、元素结束、文档结束等事件时,就会向外发送一次事件,而开发者则可以通过编写事件监听器处理这些事件,以此来获取XML文档里的信息。

    DOM标准简单易用,但是它需要一次性地读取整个XML文档,而且在程序运行期间,整个DOM树常驻内存,导致系统开销过大。SAX解析方式占用内存小,处理速度更快。
    由于DOM一次性将整个XML文档全部读入内存,因此可以随机访问XML文档的每个元素。SAX采用顺序模式来依次读取XML文档,因此无法做到随机访问XML文档的任意元素。

二、项目结构

              框住的是本实例需要的代码。

三、实例实现

<?xml version="1.0" encoding="UTF-8"?>

		Jack
24 Tom
25 Bob
22

    ps:不知道为啥,用xml格式发布就出问题,用java就不出问题~~

package xml;

import java.io.InputStream;
import java.util.List; import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory; public class SaxService {
public static List readXML(InputStream inputStream) throws Exception {
SAXParserFactory spf = SAXParserFactory.newInstance(); //创建SAXParserFactory对象(SAX解析器工厂)
SAXParser saxParser = spf.newSAXParser(); //创建SAXParser对象(SAX解析器)
MyDefaultHandle myDefaultHandle = new MyDefaultHandle(); //MyDefaultHandle对象,继承自DefaultHandle类
saxParser.parse(inputStream, myDefaultHandle); //解析XML文档(以InputStream对象的形式)
inputStream.close(); //关闭InputStream对象
return myDefaultHandle.getPersonList(); //返回XML文档中的数据列表
}
}

package xml;

import java.util.ArrayList;
import java.util.List; import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler; public class MyDefaultHandle extends DefaultHandler {
private Person person = null; //存储解析得到的单个Person对象
private List personList = null; //存储解析得到的所有Person对象
private String currentTag = null; //正在解析的元素的标签 private static final String TAG = "MyDefaultHandle"; //Log标签 public List getPersonList() {
return personList;
} public void startDocument() throws SAXException {
personList = new ArrayList();
System.out.println("开始解析");
} public void startElement(String uri, String localName, String qName,
Attributes attributes) throws SAXException {
if(qName.equals("person")) { //当遇到标签时,创建一个Person对象
person = new Person();
if(attributes!=null) {
person.setId(Integer.parseInt(attributes.getValue(0)));//将读到的id属性值存入Person对象
}
System.out.println("处理标签");
} currentTag = qName; //设置当前读到的标签
} public void characters(char[] ch, int start, int length) throws SAXException {
String currentValues = new String(ch, start, length); //获取当前标签里的内容
if(currentTag != null) {
if(currentTag.equals("name")) { //将读到的name属性值存入Person对象
person.setName(currentValues);
}else if(currentTag.equals("age")) { //将读到的age属性值存入Person对象
person.setAge(Integer.parseInt(currentValues));
}
System.out.println("处理元素");
}
} public void endElement(String uri, String localName, String qName) throws SAXException {
//当读到标签时,向列表中添加读取到的单个Person对象
if(qName.equals("person") && (person != null)) {
personList.add(person);
person = null;
System.out.println("添加一个person");
}
currentTag = null;
} public void endDocument() throws SAXException {
System.out.println("完毕");
} }

package xml;

public class Person {
private String name;
private int age;
private int id; public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}

     不知道咋回事Test类就是插不进去,显示一半,气死了。。直接看吧

package xml;

import java.io.IOException;

import java.io.InputStream;

import java.net.HttpURLConnection;

import java.net.MalformedURLException;

import java.net.URL;

import java.util.List;

public class Test {

    static String URL_PATH = "http://localhost:8080/TestGet/person.xml";

   
    public static InputStream getInputStream() throws IOException {

        InputStream inputStream = null;

        HttpURLConnection httpURLConnection = null;

        try {

            URL url = new URL(URL_PATH);

            if (url != null) {

                httpURLConnection = (HttpURLConnection) url.openConnection();

                // 设置连接网络的超时时间

                httpURLConnection.setConnectTimeout(3000);

                httpURLConnection.setDoInput(true);

                // 设置本次http请求使用get方式请求

                httpURLConnection.setRequestMethod("GET");

                int responseCode = httpURLConnection.getResponseCode();

                if (responseCode == 200) {

                    // 从服务器获得一个输入流

                    inputStream = httpURLConnection.getInputStream();

                }

            }

        } catch (MalformedURLException e) {

            // TODO Auto-generated catch block

            e.printStackTrace();

        }

 
        return inputStream;

    }

    public static void main(String[] args) throws IOException, Exception {

        // TODO Auto-generated method stub

        if(getInputStream()==null) {

            System.out.println("读取失败");

            return ;

        }

        List<Person> person = SaxService.readXML(getInputStream());

        System.out.println(person.size());

        for(int i=0; i<person.size(); i++)

            System.out.println("id:"+person.get(i).getId()+"age:"+person.get(i).getAge()

                    +"name:"+person.get(i).getName());

    }

}


    结果如下:

开始解析
处理元素
处理标签
处理元素
处理元素
处理元素
添加一个person
处理标签
处理元素
处理元素
处理元素
添加一个person
处理标签
处理元素
处理元素
处理元素
添加一个person
完毕
3
id:1age:24name:Jack
id:2age:25name:Tom
id:3age:22name:Bob

四、遗留问题

    1.sax解析中Name和localName什么区别,想到这个是因为一哥们用的localName和person判断他表示结果对了,费解???

    2.endElement的if里把person设置为null是为了防止重复触发该事件,之后把currentTag设置为null是何意?莫非存在如下情况,费解啊。。。

                      

Android使用SAX解析xml的更多相关文章

  1. Android之SAX解析XML

    一.SAX解析方法介绍 SAX(Simple API for XML)是一个解析速度快并且占用内存少的XML解析器,非常适合用于Android等移动设备. SAX解析器是一种基于事件的解析器,事件驱动 ...

  2. Android使用SAX解析XML(1)

    可扩展标记语言XML是一种数据交换格式,允许用户自己定义,适合Web传输,能提供独立于程序的数据.XML在Android中也有广泛的应用,Android解析XML的方法有很多,本文介绍使用SAX(Si ...

  3. Android使用SAX解析XML(4)

    util.java文件如下: package com.hzhi.my_sax; import java.io.IOException; import java.io.InputStream; impo ...

  4. Android使用SAX解析XML(5)

    parse_handler.java文件: package com.hzhi.my_sax; import org.xml.sax.Attributes; import org.xml.sax.SAX ...

  5. Android使用SAX解析XML(3)

    主界面MainActivity.java: package com.hzhi.my_sax; import java.util.ArrayList; import android.os.Bundle; ...

  6. Android使用SAX解析XML(2)

    school类包含了一个major列表,可以增加该列表的元素,以及返回该列表,还实现了Parcelable.Creator接口. package com.hzhi.my_sax; import jav ...

  7. Android使用SAX解析XML(6)

    应用截图: (1)开始运行时 (2)选择学院 (3)选择专业 (4)选择班级 (5)选择班级的详细信息 本文参考了<Android平台开发之旅>.

  8. Android 使用pull,sax解析xml

    pull解析xml文件 1.获得XmlpullParser类的引用 这里有两种方法 //解析器工厂 XmlPullParserFactory factory=XmlPullParserFactory. ...

  9. Android SAX解析XML

    本篇讲解一下SAX解析XML这种方式,首先来看一下它的基本介绍: SAX是一种以事件驱动的XML API,由它定义的事件流可以指定从解析器传到专门的处理程序的代码的XML结构,简单的讲,它是种解析速度 ...

随机推荐

  1. asp.net分页控件库

    AspNetPager分页控件 AspNetPager分页控件解决了分页中的很多问题,直接采用该控件进行分页处理,会将繁琐的分页工作变得简单化,下面是我如何使用AspNetPager控件进行分页处理的 ...

  2. C#基础篇02

    首先:一个完整的方法是包括两部分的,代码和注释!!!! 程序的调试: 3:设置断点:  断点之前的程序已经确保正确,可是在断点后的部分可能出现错误,所以设置完断点后,直接点击启动,然后按F11逐步棸的 ...

  3. Lambda表达式(C语言-gcc编译器)

    前言 先来啰嗦几句,身边的朋友,同事都喜欢在博客上记录自己在学习计算机编程技术路程上的一些问题和心得.就我个人而言,这是个好习惯,特别是在计算机编程领域,技术方向种类繁多,永无止境.所以,我也开始我人 ...

  4. xml、xhtml、html、dhtml的区别

    1.XML 可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言. 可扩展标记语言可以对文档和数据进行结构化处理,从而能够在部门.客户和供应商之间进行交换,实现动态内 ...

  5. .net中压缩和解压缩的处理

    最近在网上查了一下在.net中进行压缩和解压缩的方法,方法有很多,我找到了以下几种: 1.利用.net自带的压缩和解压缩方法GZip 参考代码如下: //======================= ...

  6. V$SESSION_LONGOPS

    对大部分DBA来说,V$SESSION_LONGOPS视图都不会陌生,以前在面试的时候,也有一些企业会问到如何查询数据库中运行时间比较长的SQL,就可以通过这个视图来查看.V$SESSION_LONG ...

  7. ASP.NET 预编译

    ASP.NET 预编译概述 https://msdn.microsoft.com/zh-cn/library/bb398860%28v=VS.90%29.aspx 如何:预编译 ASP.NET 网站以 ...

  8. javee学习-通过ServletContext对象实现数据共享

    1,设置值. ServletContext context = this.getServletConfig().getServletContext();//获得ServletContext对象 // ...

  9. 例子: 自制Flask首页导航.

    # -*- coding:utf-8 -*- ''' Created on 2015年10月19日 ''' from flask import Flask, render_template impor ...

  10. (zzuli)1907 小火山的宝藏收益

    Description 进去宝藏后, 小火山发现宝藏有N个房间,且这n个房间通过N-1道门联通. 每一个房间都有一个价值为Ai的宝藏, 但是每一个房间也都存在一个机关.如果小火山取走了这个房间的宝藏, ...