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

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

  public class SAXReader extends DefaultHandler {

  java.util.Stack tags=new java.util.Stack();

  //--------------XML Content-------------

  String text=null;

  String url=null;

  String author=null;

  String description=null;

  String day=null;

  String year=null;

  String month=null;

  //----------------------------------------------

  public void endDocument() throws SAXException {

  System.out.println("------Parse End--------");

  }

  public void startDocument() throws SAXException {

  System.out.println("------Parse Begin--------");

  }

  public void startElement(String p0, String p1, String p2, Attributes p3) throws SAXException {

  tags.push(p1);

  }

  public void endElement(String p0, String p1, String p2) throws SAXException {

  tags.pop();

  //一个link节点的信息收集齐了,将其格式化输出

  if (p1.equals("link")) printout();

  }

  public void characters(char[] p0, int p1, int p2) throws SAXException {

  //从栈中得到当前节点的信息

  String tag=(String) tags.peek();

  if (tag.equals("text")) text=new String(p0,p1,p2);

  else if (tag.equals("url")) url=new String(p0,p1,p2);

  else if (tag.equals("author")) author=new String(p0,p1,p2);

  else if (tag.equals("day")) day=new String(p0,p1,p2);

  else if (tag.equals("month")) month=new String(p0,p1,p2);

  else if (tag.equals("year")) year=new String(p0,p1,p2);

  else if (tag.equals("description")) year=new String(p0,p1,p2);

  }

  private void printout(){

  System.out.print("Content: ");

  System.out.println(text);

  System.out.print("URL: ");

  System.out.println(url);

  System.out.print("Author: ");

  System.out.println(author);

  System.out.print("Date: ");

  System.out.println(day+"-"+month+"-"+year);

  System.out.print("Description: ");

  System.out.println(description);

  System.out.println();

  }

  static public void main(String[] args) {

  String filename = null;

  boolean validation = false;

  filename="links.xml";

  SAXParserFactory spf = SAXParserFactory.newInstance();

  SAXParser saxParser=null;

  try {

  saxParser = spf.newSAXParser();

  } catch (Exception ex) {

  System.err.println(ex);

  System.exit(1);

  }

  try {

  saxParser.parse(new File(filename),new SAXReader());

  } catch (SAXException se) {

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

  System.exit(1);

  } catch (IOException ioe) {

  System.err.println(ioe);

  System.exit(1);

  }

  }

  }

  在这儿虽然没有使用到栈的分析,但实际上栈的分析是一件很容易的事情,应为java.util.Stack继承了java.util.Vector类,而且Stack中的元素是按栈的结构由底至上排列的,因个,我们可以使用Vector类的size()方法来得到Stack的元素个数,还可以使用Vector的get(int)方法来得到具体的每一个元属。实际上,如果把Stack的元素从底向上逐一排列出来,我们就得到了从XML根节点到当前节点的一条唯一的路径,有了这条路径的信息,文档的结构就在清楚不过了。

  小节

  好了,到这儿为止,我们已经掌握了对于XML编程的两大利器:DOM和SAX,也知道了该如何在一个Java程序中使用它们。DOM编程相对简单,但是速度比较慢,占用内存多,而SAX编程复杂一些,但是速度快,占用内存少。所以,我们应该根据不同的环境选择使用不同的方法。大部分的XML应用基本都可以用它们来解决。需要特别说明的是,DOM和SAX其实都是语言无关的,并非Java所独有,也就是说,只要有相应的语言实现,DOM和SAX可以应用在任何面向对象的语言中。

  点击查看:2011年计算机二级考试JAVA知识点整理汇总

上一页234下一页

视频学习

我考网版权与免责声明

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

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

最近更新

社区交流

考试问答