2011年计算机二级JAVA知识点:Java与XML联合编程之SAX篇

来源:计算机等级考试    发布时间:2012-08-29    计算机等级考试视频    评论

  public void endDocument() throws SAXException {

  Enumeration e = tags.keys();

  while (e.hasMoreElements()) {

  String tag = (String)e.nextElement();

  int count = ((Integer)tags.get(tag)).intValue();

  System.out.println("Tag <" + tag + "> occurs " + count

  + " times");

  }

  }

  //程序入口,用来完成解析工作

  static public void main(String[] args) {

  String filename = null;

  boolean validation = false;

  filename="links.xml";

  SAXParserFactory spf = SAXParserFactory.newInstance();

  XMLReader xmlReader = null;

  SAXParser saxParser=null;

  try {

  // 创建一个解析器SAXParser对象

  saxParser = spf.newSAXParser();

  // 得到SAXParser中封装的SAX XMLReader

  xmlReader = saxParser.getXMLReader();

  } catch (Exception ex) {

  System.err.println(ex);

  System.exit(1);

  }

  try {

  //使用指定的ContentHandler,解析给XML文件,这儿要注意的是,为了

  //程序的简单起见,这儿将主程序和ContentHandler放在了一起。实际上

  //main方法中所作的所有事情,都与ContentHandler无关。

  xmlReader.parse(new File(filename),new SAXCounter());

  } catch (SAXException se) {

  System.err.println(se.getMessage());

  System.exit(1);

  } catch (IOException ioe) {

  System.err.println(ioe);

  System.exit(1);

  }

  }

  }

  我们来看看这段程序作了些什么,在main()方法中,主要做的就是创建解析器,然后解析文档。实际上,在这儿创建SAXParser对象的时候,为了使程序代码于具体的解析器无关,使用了同DOM中一样的设计技巧:通过一个SAXParserFactory类来创建具体的SAXParser对象,这样,当需要使用不同的解析器的时候,要改变的,只是一个环境变量的值,而程序的代码可以保持不变。这就是FactoryMethod模式的思想。在这儿不再具体讲了,如果还有不明白的,可以参看上面DOM中的解释,原理是一样的。

  不过在这儿还有一点点要注意的地方,就是SAXParser类和XMLReader类之间的关系。你可能有些迷糊了吧,实际上SAXParser是JAXP中对XMLReader的一个封装类,而XMLReader是定义在SAX2.0种的一个用来解析文档的接口。你可以同样的调用SAXParser或者XMLReader中的parser()方法来解析文档,效果是完全一样的。不过在SAXParser中的parser()方法接受更多的参数,可以对不同的XML文档数据源进行解析,因而使用起来要比XMLReader要方便一些。

  这个例子仅仅涉及了SAX的一点皮毛,而下面的这个,可就要高级一些了。下面我们要实现的功能,在DOM的例子中已经有实现了,就是从XML文档中读出内容并格式化输出,虽然程序逻辑看起来还是很简单,但是SAX可不比DOM哦,看着吧。

  前面说过,当遇到一个开始标签的时候,在startElement()方法中,我们并不能够得到这个标签在XML文档中所处的位置。这在处理XML文档的时候是个大麻烦,因为在XML中标签的语义,有一部分是由其所处的位置所决定的。而且在一些需要验证文档结构的程序中,这更是一个问题。当然,没有解决不了的问题了,我们可以使用一个栈来实现对文档结构的纪录。

  栈的特点是先进先出,我们现在的想法是,在startElemnt()方法中用push将这个标签的名字添加到栈中,在endElement()方法中在把它pop出来。我们知道对一个结构良好的XML而言,其嵌套结构是完备的,每一个开始标签总会对应一个结束标签,而且不会出现标签嵌套之间的错位。因而,每一次startElement()方法的调用,必然会对应一个endElement()方法的调用,这样push和pop也是成对出现的,我们只需要分析栈的结构,就可以很容易的知道当前标签所处在文档结构中的位置了。

视频学习

我考网版权与免责声明

① 凡本网注明稿件来源为"原创"的所有文字、图片和音视频稿件,版权均属本网所有。任何媒体、网站或个人转载、链接转贴或以其他方式复制发表时必须注明"稿件来源:我考网",违者本网将依法追究责任;

② 本网部分稿件来源于网络,任何单位或个人认为我考网发布的内容可能涉嫌侵犯其合法权益,应该及时向我考网书面反馈,并提供身份证明、权属证明及详细侵权情况证明,我考网在收到上述法律文件后,将会尽快移除被控侵权内容。

最近更新

社区交流

考试问答