成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Java中dom4j讀取配置文件實現抽象工廠+反射

開發 后端
在Donet中實現反射的主要原理是:將差異配置在config配置文件里面,并利用接口,通過在U的bin路徑下面找到具體實現的名字來使程序運行。

在Java中也可以同Donet一樣,將差異配置在配置文件里面。另外,我們采用下面的方式實現,將會更加便捷。

邏輯描述:

現在我們想在B層和D層加上接口層,并使用工廠。而我們可以將創建B和創建D看作是兩個系列,然后就可以使用抽象工廠進行創建了。

配置文件:beans-config.xml。service-class與dao-class分別對應兩個系列的產品。子菜單中id對應接口的命名空間,class對應實現類的命名空間。

  1. [html] view plaincopyprint? 
  2.  
  3.     <?xml version="1.0" encoding="UTF-8"?>   
  4.     <beans>   
  5.          <service-class>   
  6.             <service id="com.xxjstgb.drp.basedata.manager.ItemManager" class="com.xxjstgb.drp.basedata.manager.ItemManagerImpl" />   
  7.             <service id="com.xxjstgb.drp.flowcard.manager.FlowCardManager" class="com.xxjstgb.drp.flowcard.manager.impl.FlowCardManagerImpl" />   
  8.          </service-class>   
  9.          <dao-class>   
  10.             <dao id="com.xxjstgb.drp.basedata.dao.ItemDao" class="com.xxjstgb.drp.basedata.dao.ItemDao4OracleImpl" />   
  11.             <dao id="com.xxjstgb.drp.flowcard.dao.FlowCardDao" class="com.xxjstgb.drp.flowcard.dao.impl.FlowCardDaoImpl" />   
  12.          </dao-class>   
  13.     </beans>   

抽象工廠:BeanFactory。通過讀取配置文件,取得相關對象,并將相關創建好的對象保存在Map中。

  1. [java] view plaincopyprint? 
  2.  
  3.     package com.xxjstgb.drp.util;   
  4.        
  5.     import java.util.HashMap;   
  6.     import java.util.Map;   
  7.        
  8.     //dom4j   
  9.     import org.dom4j.Document;   
  10.     import org.dom4j.DocumentException;   
  11.     import org.dom4j.Element;   
  12.     import org.dom4j.io.SAXReader;   
  13.        
  14.     import com.xxjstgb.drp.basedata.dao.ItemDao;   
  15.     import com.xxjstgb.drp.basedata.manager.ItemManager;   
  16.     import com.xxjstgb.drp.flowcard.dao.FlowCardDao;   
  17.     import com.xxjstgb.drp.flowcard.manager.FlowCardManager;   
  18.        
  19.     /**  
  20.      * 抽象工廠,主要創建兩個系列的產品  
  21.      * 1、Manager系列  
  22.      * 2、Dao系列產品  
  23.      * @author liuzhengquan  
  24.      *  
  25.      */   
  26.     public class BeanFactory {   
  27.            
  28.         private static BeanFactory instance=new BeanFactory();   
  29.            
  30.         //系統缺省配置文件名稱   
  31.         private final String beansConfigFile="beans-config.xml";   
  32.            
  33.         //保存Dao相關對象   
  34.         private Document doc;   
  35.            
  36.         /*  
  37.          * key=配置文件中的id值  
  38.          * value=對應了該Id的對象  
  39.          */   
  40.         private Map serviceMap = new HashMap();//保存Service相關對象   
  41.         private Map daoMap = new HashMap();//保存Dao相關對象   
  42.            
  43.            
  44.         private BeanFactory(){   
  45.             try {   
  46.                 doc=new SAXReader().read(Thread.currentThread().getContextClassLoader().getResourceAsStream(beansConfigFile));   
  47.             } catch (DocumentException e) {   
  48.                 e.printStackTrace();   
  49.                 throw new RuntimeException();   
  50.             }   
  51.         }   
  52.            
  53.         public static BeanFactory getInstance(){   
  54.             return instance;   
  55.         }   
  56.            
  57.         /**  
  58.          * 根據產品編號取得Service系列產品  
  59.          * @param serviceId  
  60.          * @return  
  61.          */   
  62.         public synchronized Object getServiceObject(Class c){   
  63.             //如果存在相關對象實例,返回   
  64.             if(serviceMap.containsKey(c.getName())){   
  65.                 return serviceMap.get(c.getName());   
  66.             }   
  67.             Element beanElt=(Element)doc.selectSingleNode("//service[@id=\""+ c.getName() + "\"]");   
  68.             String className=beanElt.attributeValue("class");   
  69.             Object service=null;   
  70.                
  71.             try {   
  72.                 service=Class.forName(className).newInstance();   
  73.                    
  74.                 //將創建好的對象放到Map中   
  75.                 serviceMap.put(c.getName(), service);   
  76.             } catch (Exception e) {   
  77.                 throw new RuntimeException();   
  78.             }   
  79.             return service;   
  80.         }   
  81.            
  82.         /**  
  83.          * 根據產品編號取得Dao系列產品  
  84.          * @param daoId  
  85.          * @return  
  86.          */   
  87.         public synchronized Object getDaoObject(Class c){   
  88.             //如果存在相關對象實例,返回   
  89.             if(daoMap.containsKey(c.getName())){   
  90.                 return daoMap.get(c.getName());   
  91.             }   
  92.             Element beanElt=(Element)doc.selectSingleNode("//dao[@id=\""+c.getName()+"\"]");   
  93.             String className=beanElt.attributeValue("class");   
  94.             Object dao=null;   
  95.                
  96.             try {   
  97.                 dao=Class.forName(className).newInstance();   
  98.                    
  99.                 //將創建好的對象放到Map中   
  100.                 daoMap.put(c.getName(), dao);   
  101.             } catch (Exception e) {   
  102.                 throw new RuntimeException();   
  103.             }   
  104.             return dao;   
  105.         }   
  106.            
  107.            
  108.         /**  
  109.          * 測試  
  110.          * @param args  
  111.          */   
  112.         public static void main(String[] args){   
  113.             ItemManager itemManager=(ItemManager)BeanFactory.getInstance().getServiceObject(ItemManager.class);   
  114.             System.out.println("itemManager"+itemManager);   
  115.                
  116.             ItemDao itemDao=(ItemDao)BeanFactory.getInstance().getDaoObject(ItemDao.class);   
  117.             System.out.println("itemDao:"+itemDao);   
  118.                
  119.             FlowCardManager flowCardManager=(FlowCardManager)BeanFactory.getInstance().getServiceObject(FlowCardManager.class);   
  120.             //FlowCardManager flowCardManager=new FlowCardManagerImpl();   
  121.             System.out.println(flowCardManager);   
  122.                
  123.             FlowCardDao flowCardDao=(FlowCardDao)BeanFactory.getInstance().getDaoObject(FlowCardDao.class);   
  124.             //FlowCardDao flowCardDao=new FlowCardDaoImpl();   
  125.             System.out.println("flowCardDao:"+flowCardDao);   
  126.         }   
  127.            
  128.     }   

運行結果:

總結:

通過抽象工廠+反射的實現,調用層就可以只認識接口,而無須與具體實現打交道,實現了解耦合。同時,由于配置文件里面是接口和實現的命名空間,我們就可以用相應接口的.class屬性,點出命名空間,將配置文件的id和class都以鍵值對的形式配置在Map中,實現反射。

原文鏈接:http://blog.csdn.net/liu765023051/article/details/8986629

責任編輯:陳四芳 來源: csdn博客
相關推薦

2011-04-13 09:30:28

dom4j

2024-07-22 08:16:15

2009-06-23 14:17:00

Dom4j

2009-04-02 17:37:38

dom4jXMLJava

2013-03-04 10:40:34

三層架構架構設計

2009-02-01 14:07:01

J2EEXMLXML配置文件

2012-05-30 10:03:57

dom4jXML亂碼

2011-08-29 16:48:50

Lua配置文件C++

2023-08-07 16:14:32

propertiesSpring框架

2024-03-06 13:19:19

工廠模式Python函數

2009-08-13 09:58:55

C#讀取配置文件

2009-08-13 09:16:57

C#讀取配置文件

2010-08-03 09:20:33

Flex讀取XML配置

2011-06-14 16:07:13

Qt QSettings類

2013-07-30 11:30:42

Windows PhoWindows Pho

2013-06-08 13:29:27

Android開發DOM讀取XMLXML解析

2014-12-31 14:09:23

xml解析

2010-01-12 16:53:23

Fedora Core

2009-04-24 21:31:54

Vmwareesx虛擬化

2019-11-22 10:00:53

ICC配置文件Windows 10
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: av网址在线播放 | 久久久久亚洲精品 | 二区在线观看 | 免费一级毛片 | 国产日韩精品在线 | 亚洲一区精品在线 | 国产午夜精品久久久久 | 91 视频网站 | 国产精品久久久久久一区二区三区 | 国产精品日韩在线观看 | 黄色在线免费观看视频 | 欧美日韩在线视频一区二区 | 激情91| 五月婷婷丁香婷婷 | 成人免费毛片片v | 亚洲网站在线观看 | 麻豆视频国产在线观看 | 精品一区二区三区在线观看 | 国产亚洲高清视频 | 日韩精品久久久久 | 成人精品视频99在线观看免费 | 午夜网| 6080yy精品一区二区三区 | 欧美日韩一区二区在线观看 | 国产精品99久久久久久久久久久久 | 国产精品久久国产精品99 gif | 久久极品| 日韩高清成人 | 亚洲成人一区二区 | 天堂综合网 | 日韩一二三区视频 | 九九综合 | 精品一区二区av | 91欧美精品成人综合在线观看 | 97精品国产一区二区三区 | 久久久久久黄 | 亚洲欧美国产精品久久 | 欧美在线视频一区二区 | 免费一级片| 欧美一区二区三区在线播放 | 亚洲日韩中文字幕一区 |