麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

利用緩存機制快速讀取XML文件數據

2019-11-18 12:47:07
字體:
來源:轉載
供稿:網友

  接到一個任務,讓我做一個公司網站的后臺治理系統。要求很簡單,就一個新聞發布模塊和一個招聘信息發布模塊。但不能用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.  } 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 (Illegal
accessException 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());
  }
  }
  
  第一次會從文件中讀出數據,第二次就會從緩存中讀取了,試著多讀幾次速度明顯快很多。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: av在线播放免费观看 | 一级美女大片 | 中文字幕天堂在线 | 午夜天堂在线 | 91久久精品一 | 99爱视频在线观看 | xp123精品视频 | 国产精品色综合 | 免费看污视频在线观看 | 国产日产精品一区二区三区四区 | 国产1区2| 激情97 | 99视频在线观看视频 | 98国内自拍在线视频 | 一级一级一级一级毛片 | 日本黄色a视频 | 精品一区二区电影 | sese在线视频 | 国产噜噜噜 | 2018亚洲男人天堂 | 黄色一级电影网 | 91精品国产92久久久久 | 87成人免费看片 | 中文字幕亚洲情99在线 | 成人在线视频免费看 | 国产精品视频中文字幕 | 福利在线免费视频 | 韩国一级免费视频 | 视频一区二区三区在线观看 | 天天草天天干天天 | 国产亚洲精品久久久久久久久 | 国产一区二区影视 | 视频一区二区在线播放 | 2021国产精品 | 美女亚洲综合 | xxxx18韩国护士hd老师 | 成人免费一区二区三区 | 九九热精| 国产精品刺激对白麻豆99 | 中文字幕免费一区 | 最新午夜综合福利视频 |