一、理论准备

    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. Linux软连接和硬链接(摘录)

    1.Linux链接概念Linux链接分两种,一种被称为硬链接(Hard Link),另一种被称为符号链接(Symbolic Link).默认情况下,ln命令产生硬链接. [硬连接]硬连接指通过索引节点 ...

  2. JAVA练习

    JAVA基础练习 1.给java,stb,sql三门科目的成绩算出JAVA和SQL的成绩差,JAVA和SQL的成绩共是,三门课的总分是,三门课的平均分是多少 import java.util.Scan ...

  3. 程序员带你学习安卓开发-XML文档的创建与解析

    这是程序员带你学习安卓开发系列教程.本文章致力于面向对象程序员可以快速学习开发安卓技术. 上篇文章:程序员带你学习安卓开发系列-Android文件存储 因知识连贯性推荐关注头条号:做全栈攻城狮.从头开 ...

  4. c#之内置类型

    内置类型:就是.NET Framework System命名空间中写好的类型. 下面看看C#都有哪些内置类型 上面的内置类型,除了string和object外,其他的都被称作简单类型.也可以把左边的看 ...

  5. 参加魅族 flyme 互联网编程大赛的一些感受

    为期两天的 flyme 编程大赛已经结束了,自己也在这次大赛中深有感触,受益颇丰. 在这次大赛里,认识到了很多厉害的开发者,有单打独斗的,也有四五成群的.开幕致辞上看到很多非常有创意的点子,感觉每个队 ...

  6. datejs lib

    // Get today's date Date.today(); // Add 5 days to today Date.today().add(5).days(); // Get Friday o ...

  7. eclipse和android studio导入工程的错误

    eclipse中导入工程,需要注意导入的工程是什么,android 工程和java工程是有区别的.如果导入错误了,调起来也比较麻烦.因为入口错了呀. 特别在android studio工程,从其它人的 ...

  8. 冒泡排序算法(C#实现)

    简单的冒泡排序算法,代码如下: ] = temp; hasExchangeAction =true; //发生过互换 } } if (!hasExchangeAction) //如果没有发生过互换,则 ...

  9. Tomcat中JSP引擎工作原理

    http://blog.csdn.net/linjiaxingqqqq/article/details/7164449 JSP运行环境: 执行JSP代码需要在服务器上安装JSP引擎,比较常见的引擎有W ...

  10. HTML_常见命令学习笔记

    1. java类中的这段代码 out.println(" <div class='line'>"); out.println(" <div align= ...