动态网站制作指南
[  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
电脑书籍下载:程序设计书籍 | 数据库教程书籍 | 平面与多媒体书籍 | 网络通讯书籍 | 系统管理书籍 | 网络安全书籍 | 认证考试书籍
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Java教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ Java教程 ]的信息



本月文章推荐
.如何保护Java程序.
.Java新手入门需要掌握的30个基本.
.Hibernate 连Tomcat数据源配置.
.优化JavaApplet的加载过程.
.详述:JAVA也能克隆!.
.在java中对数组a[depth]的理解.
.各类Java资源收集(更新中……).
.前车之覆,后车之鉴 --开源项目经.
.JSF是初学者进入Java Web世界的跳.
.[学习小记]Java的反射机制.
.如何在JAVASE中使用Hibernate.
.Microsoft .NET与J2EE的比较[E].
.项目经理需知的Java技术问题.
.Java语言中链表和双向链表的实现.
.使用 Java 连接处于proxy(or 防火.
.新手入门 Eclipse插件的安装与配.
.Class文件详解 (2).
.无提示信息禁止鼠标右键的脚本.
.企业应用级别的Ant模组编译环境.
.Displaytag1.1版发布了.

利用缓存机制快速读取XML文件数据

文章类别:Java教程 | 发表日期:2008-1-5 |



  接到一个任务,让我做一个公司网站的后台治理系统。要求很简单,就一个新闻发布模块和一个招聘信息发布模块。但不能用DB,只能用文件存取的形式实现。
  
  不用考虑肯定是用XML文件进行数据的存取了,以前做毕设的时候也曾经实现过类似的功能,所以关于XML的读取并没有问题。要害是假如考虑到性能的问题就值得推敲一下了,我是新人,以前也没做过什么设计,所以做出的东西在一些人眼中可能会有些稚嫩,那也没关系,走自己的路让别人去说吧:)
  
  假如频繁解析文件,速度肯定受到影响,在文件非常大的情况下,甚至是无法忍受的。假如在服务器启动的时候先把文件中的数据封装成对象数组读入到缓存中,每次访问的时候先判定一下要访问的文件实体有没有被更新,假如没有被更新,就直接从缓存中将想要的数据读出来,当然假如文件被更新了,那只好老老实实的解析文件读出想要的数据。治理者对文件的修改次数究竟是少数,更多的是访问者的访问次数。这样就能很大的提高了访问速度,代价是要占用一定的内存空间,但相比之下应该算小巫吧。
  
  下面把简单实现的几个Class说一说。
  
  一 首先实现一个Cache类,里面有读取对象的方法get(),假如文件没有被修改则直接从HashMap里面将对象取出,假如文件被修改则调用readObject()方法实现从文件中读出数据,并同时将读出的数据放入HashMap里,将原来的对象覆盖。这样下次再读数据的时候就可以从缓存中直接读到,并且保证是最新的数据。还有一个判定文件是否被修改的方法getModified();
  

  代码实现如下:
  
  import Java.io.File;
  import java.util.HashMap;
  
  public class Cache {
  
  HashMap mapLastModified = new HashMap();
  HashMap mapValues = new HashMap();
  public Cache() {
  super();
  }
  public Object get(String name, String path, Class clsParser, Class clsInstantiator, Class clsObj) {
  Object obj = null;
  String absPath = getClass().getResource(path).getPath();
  Long modified = getModified(name, absPath);
  if (modified != null) {
  obj = readObject(absPath, clsParser, clsInstantiator, clsObj);
  
  mapLastModified.put(name, modified);
  mapValues.put(name, obj);
  System.out.println("get object from file");
  } else {
  obj = mapValues.get(name);
  System.out.println("get object from cache");
  }
  return obj;
  }
  
  private Long getModified(String name, String path) {
  Long modified = new Long(new File(path).lastModified());
  Long saveModified = (Long) mapLastModified.get(name);
  if ((saveModified != null) && (saveModified.longValue() >= modified.longValue())) {
  modified = null;
  }
  return modified;
  }
  
  private Object readObject(String path, Class clsParser, Class clsInstantiator, Class clsObj) {
  try {
  FileParser parser = (FileParser) clsParser.newInstance();
  Instantiator instantiator = (Instantiator) clsInstantiator.newInstance();
  
  Object config = parser.parse(path);
  return instantiator.instantiate(clsObj, config);
  
  } catch (InstantiationException e) {
  e.printStackTrace();
  } catch (IllegalAccessException e) {
  e.printStackTrace();
  }
  return null;
  }
  }
  
  二 解析XML文件的类XmlFileParser,
  

  为了方便处理不同文件的解析,在这里先定义一个接口FileParser,XmlFileParser实现了它,假如还有诸如对其他种类文件的解析也可以实现它。
  
  //FileParser.java
  public interface FileParser {
  Object parse(String path);
  
  }
  
  //XmlFileParser.java
  //采用Jdom的解析方式
  
  import java.io.FileInputStream;
  import java.io.IOException;
  import org.jdom.Document;
  import org.jdom.Element;
  import org.jdom.input.SAXBuilder;
  
  public class XmlFileParser implements FileParser {
  
  public XmlFileParser() {
  super();
  }
  
  public Object parse(String path) {
  
  FileInputStream fi = null;
  try {
  fi = new FileInputStream(path);
  SAXBuilder sb = new SAXBuilder();
  Document doc = sb.build(fi);
  Element root = doc.getRootElement();
  return root.getChildren();
  } catch (Exception e) {
  e.printStackTrace();
  } finally {
  try {
  fi.close();
  } catch (IOException e1) {
  }
  }
  }
  }
  
  三 接下来是一个实例化处理的类ListTypeInstantiator,同样为了方便处理不同文件的实例化,在这里先定义一个接口Instantiator,ListTypeInstantiator实现了它。
  

  //Instantiator.java
  public interface Instantiator {
  Object instantiate(Class clazz, Object configuration);
  }
  
  //ListTypeInstantiator.java
  import java.util.ArrayList;
  import java.util.List;
  
  import org.apache.commons.beanutils.BeanUtils;
  import org.jdom.Element;
  
  public class ListTypeInstantiator implements Instantiator {
  
  public ListTypeInstantiator() {
  super();
  }
  
  public Object instantiate(Class clazz, Object configuration) {
  List arr = new ArrayList();
  Object bean = null;
  
  List children = (List) configuration;
  Element child = null;
  
  List attributes = null;
  Element attribute = null;
  
  try {
  for(int i=0; i<children.size(); i++) {
  child = (Element) children.get(i);
  bean = clazz.newInstance();
  attributes = child.getChildren();
  for(int j=0; j<attributes.size(); j++) {
  attribute = (Element) attributes.get(j);
  BeanUtils.setProperty(bean, attribute.getName(), attribute.getText());
  }
  arr.add(bean);
  }
  } catch(Exception e) {
  e.printStackTrace();
  }
  return arr;
  }
  }
  
  四 另外还需要一个封装我想要数据形式的JavaBean,这里设为NewsBean{}.
  

  //NewsBean.java
  public class NewsBean {
  
  private Long id;
  private String newsTitle;
  private String newsContent;
  private String newsType;
  private String deployDate;
  private String cancelDate;
  
  public Long getId() {
  return id;
  }
  public void setId(Long id) {
  this.id = id;
  }
  public String getNewsTitle() {
  return newsTitle;
  }
  public void setNewsTitle(String newsTitle) {
  this.newsTitle = newsTitle;
  }
  public String getNewsContent() {
  return newsContent;
  }
  public void setNewsContent(String newsContent) {
  this.newsContent = newsContent;
  }
  public String getNewsType() {
  return newsType;
  }
  public void setNewsType(String newsType) {
  this.newsType = newsType;
  }
  public String getDeployDate() {
  return deployDate;
  }
  public void setDeployDate(String deployDate) {
  this.deployDate = deployDate;
  }
  public String getCancelDate() {
  return cancelDate;
  }
  public void setCancelDate(String cancelDate) {
  this.cancelDate = cancelDate;
  }
  }
  
  五 最后一步测试结果,将news.xml文件放到classes目录下。
  

  //MainClass.java
  
  import java.util.List;
  public class MainClass{
  
  public static void main(String[] args) throws Exception {
  
  List news1 = null;
  List news2 = null;
  NewsBean bean = null;
  
  news1 = (List)Cache.get(
  "news", "/news.xml",
  XmlFileParser.class, ListTypeInstantiator.class, NewsBean.class);
  for (int i = 0; i < news1.size(); i++) {
  bean = (NewsBean) news1.get(i);
  System.out.println(bean.getId());
  System.out.println(bean.getNewsTitle());
  System.out.println(bean.getNewsContent());
  System.out.println(bean.getNewsType());
  System.out.println(bean.getDeployDate());
  System.out.println(bean.getCancelDate());
  }
  news2 = (List)Cache.get(
  "news", "/news.xml",
  XmlFileParser.class, ListTypeInstantiator.class, NewsBean.class);
  for (int i = 0; i < news2.size(); i++) {
  bean = (NewsBean) news2.get(i);
  System.out.println(bean.getId());
  System.out.println(bean.getNewsTitle());
  System.out.println(bean.getNewsContent());
  System.out.println(bean.getNewsType());
  System.out.println(bean.getDeployDate());
  System.out.println(bean.getCancelDate());
  }
  }
  
  第一次会从文件中读出数据,第二次就会从缓存中读取了,试着多读几次速度明显快很多。

上一篇:关于HTTP及XMLHTTP状态代码一览 人气:600
下一篇:如何使用JSTL标签做页面资源国际化 人气:267
点击此处浏览全部Java的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-5-20 站长俱乐部新闻发布系统 v5.19
2008-5-20 DotNetTextBox网页编辑器 v3.4.7
2008-5-20 phpMyFAQ v2.5.0 多国语言版
2008-5-20 DreamArticle 文章管理系统 v2.0
2008-5-20 Drupal v7.xdev Build080518
2008-5-20 逐迹内容管理系统AspxNuke v2.0.
2008-5-20 ajax奥运留言本 v1.0
2008-5-20 QQ空间博客全自动挂机互踩好友
2008-5-20 网人采集 v1.2.0
2008-5-7 Windows XP SP3 官方英文版
2008-5-7 Windows XP SP3 官方香港中文版
2008-5-7 Windows XP SP3 官方繁体中文版
2008-5-7 Windows XP SP3 官方简体中文版
2008-4-30 Multiple Unzip Wizard 1.02
2008-4-30 Multiple Unrar Wizard 1.0.0
2008-4-30 WinZip Install/Try/Uninstall a
2008-4-30 ZIP压缩文件修复器WzipFix 2.0
2008-4-30 Pentazip 6.01 Build 189 For Wi
  发表评论
姓 名: 验证码: [ 全部贴吧 ] [ 浏览评论 ]
内 容:
[ 汉字翻译拼音 ] [ 广告代码 ] [ 符号对照表 ] [ 进制转换 ] [ 经典小工具 ] [ 个税计算 ] [ 汉字简繁转换 ] [ 普通单位换算 ] [ 公制单位换算 ]
[ 生辰老黄历 ] [ 国内电话区号 ] [ 国家代码与域名缩写 ] [ 文字加密解密 ] [ 健康查询 ] [ 万年历 ] [ 手机号码查询 ] [ ip搜索 ] [ Google PR查询 ]
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号