Android使用SAX解析XML文档

本文介绍如何使用SAX解析器解析XML文件,并详细解释了ContentHandler接口及其常用方法,包括startDocument、endDocument、startElement、endElement和characters。此外,提供了实现ContentHandler接口的示例代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


         SAX是一个解析速度快并且占用内存少的xml解析器,非常适合用于Android等移动设备,SAX解析Xml文件采用的是事件驱动,也就是说,它并不需要解析完整个文档,在按内容顺序解析文档的过程中,SAX会判断当前读到的字符是否合法XML语法中的某部分,如果符合就会触发事件,所谓事件,其实就是一个回调(callback)方法,这此些方法(事件)定义在ContentHandler接口。下面是一些ContentHandler接口常用方法:
startDocument()
当遇到文档的开头的时候,调用这个方法,可以在其中做预处理的工作。
endDocument()
和上面的方法相对应,当文档结束的时候,调用这个方法。可以在其中做善后的工作。
startElement(String namespaceURI,String localName,String qName,Attributes atts)
当读到文档开始标签的时候,会触发这个方法。namespaceURI就是命名空间,localName是不带命名空间前缀的标签名qName
是带命名空间前缀的标签名。通过atts可以得到所有的属性名和相应的值。要注意的是SAX中一个重要特点就是它的流式处理,遇到一个标签的时候,它前不会记录下以前所碰到的标签,也就是说,在startElement()方法中,所有你所知道的信息中
就是标签的名字和属性。至于标签的嵌套结构,上层标签的名字,是否有子元素等等其它与结构相关的信息。都是不得而知的
都需要你的程序来完成。这使得SAX编程处理上没有DOM来得方便。
endElement()
这个方法和上面的方法相对应用。当遇到结束标签时调用此方法。
characters(char[] c ,int start,int length)
这个方法用来处理得的到xml内容。第一个参数为文件的字符串内容。后面两个参数是读到的字符串在这个数组中的开始位置和长度。
     只要为SAX提供实现ContentHandler接口的类,那么该类就可以得到通知事件(实际上谅是SAX调用了该类中的回调方法)。因为ContentHandler是一个接口,在使用的时候可能会有些不方便,因此,SAX还为其制定了一个Helper类:DefaultHandler,它实现了ContentHandler接口,但是其所有的方法体都是为空,在实现的时候,你只需要继承这个类
然后重写相应的方法即可。
下面是示例代码:
XML代码

<?xml version="1.0" encoding="UTF-8"?>
<Cities>
<City id="00001">
  <code>350000</code>
  <name>福州市</name>
</City>
<City id="00002">
  <code>361000</code>
  <name>厦门市</name>
</City>
<City id="00003">
  <code>351100</code>
  <name>莆田市</name>
</City>
<City id="00004">
  <code>365000</code>
  <name>三明市</name>
</City>
<City id="00005">
  <code>362000</code>
  <name>泉州市</name>
</City>
<City id="00006">
  <code>363000</code>
  <name>漳州市</name>
</City>
<City id="00007">
  <code>353000</code>
  <name>南平市</name>
</City>
</Cities>


ParseXml.java

package com.handsome.xml.parse;

import java.io.InputStream;
import java.util.List;

import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;

import com.handsome.xml.CityBean;

public class ParseXml {

public List<CityBean> getCity(InputStream inputStream) throws Exception {
  
  SAXParserFactory factory = SAXParserFactory.newInstance();
  SAXParser parser = factory.newSAXParser();
  
  ParseXmlService xmlService = new ParseXmlService();
  parser.parse(inputStream, xmlService);
  
  return xmlService.getList();
}
}


ParseXmlService.java

package com.handsome.xml.parse;

import java.util.ArrayList;
import java.util.List;

import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;

import com.handsome.xml.CityBean;

public class ParseXmlService extends DefaultHandler {

private List<CityBean> list = null;
private CityBean city = null;
private String tag = null;

public List<CityBean> getList() {
  return list;
}

/*
  * 当解析到xml头时执行此方法。即解析到:<?xml version="1.0" encoding="UTF-8"?>
  * 在这个方法里可以做一些初始化操作。
  */
@Override
public void startDocument() throws SAXException {
  list = new ArrayList<CityBean>();
}

/*
  * 当解析到开始标签时会调用此方法。如<Cities>、<City id="00001">、<code>等。
  * 每次解析到开始标签都会调用这个方法。在此方法中可以获取标签元素的属性值
  */
@Override
public void startElement(String uri, String localName, String qName,
   Attributes attributes) throws SAXException {
  /*
   * 这里判断标签名是否为City。如果是则执行下面代码获取属性值。因为在这个xml文件中,我们要获取的标签属性值只有
   * City这个标签。
   */
  if ("City".equals(localName)) {
   city = new CityBean();
   city.setId(attributes.getValue("id"));
  }
  tag = localName;
}

/*  
  * 当解析到结束标签时调用此方法。
  *  
  */
@Override
public void endElement(String uri, String localName, String qName)
   throws SAXException {

  if ("City".equals(localName)) {
   list.add(city);
   city = null;
  }
  tag = null;
}

/*
  * 当解析到文本元素的时候调用此方法
  * 
  * 
  */
 
@Override
public void characters(char[] ch, int start, int length)
   throws SAXException {
  if (tag != null) {
   String str = new String(ch, start, length);
   if (tag.equals("code")) {
    city.setCityCode(Integer.parseInt(str));
   } else if (tag.equals("name")) {
    city.setCityName(str);
   }
  }
}

@Override
public void endDocument() throws SAXException {
  // TODO Auto-generated method stub
  super.endDocument();
}

}
内容概要:本文详细探讨了基于MATLAB/SIMULINK的多载波无线通信系统仿真及性能分析,重点研究了以OFDM为代表的多载波技术。文章首先介绍了OFDM的基本原理和系统组成,随后通过仿真平台分析了不同调制方式的抗干扰性能、信道估计算法对系统性能的影响以及同步技术的实现与分析。文中提供了详细的MATLAB代码实现,涵盖OFDM系统的基本仿真、信道估计算法比较、同步算法实现和不同调制方式的性能比较。此外,还讨论了信道特征、OFDM关键技术、信道估计、同步技术和系统级仿真架构,并提出了未来的改进方向,如深度学习增强、混合波形设计和硬件加速方案。; 适合人群:具备无线通信基础知识,尤其是对OFDM技术有一定了解的研究人员和技术人员;从事无线通信系统设计与开发的工程师;高校通信工程专业的高年级本科生和研究生。; 使用场景及目标:①理解OFDM系统的工作原理及其在多径信道环境下的性能表现;②掌握MATLAB/SIMULINK在无线通信系统仿真中的应用;③评估不同调制方式、信道估计算法和同步算法的优劣;④为实际OFDM系统的设计和优化提供理论依据和技术支持。; 其他说明:本文不仅提供了详细的理论分析,还附带了大量的MATLAB代码示例,便于读者动手实践。建议读者在学习过程中结合代码进行调试和实验,以加深对OFDM技术的理解。此外,文中还涉及了一些最新的研究方向和技术趋势,如AI增强和毫米波通信,为读者提供了更广阔的视野。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值