简单工厂模式+类反射机制+配置文件+接口
简单工厂模式+类反射机制+配置文件+接口,实现变化的隔离。 例:Eclipse的java项目interfaceDemo
接口:将实现功能抽取成
方法
快递客服问题件处理详细方法山木方法pdf计算方法pdf华与华方法下载八字理论方法下载
,封装在接口中。
CustomerDAO接口,其中有一个向数据库中插入数据的方法insertCustomer(),具体实
现由特定数据库完成。
数据库实例全部实现CustomerDAO接口,实现其中insertCustomer()方法。 在main方法(用户)中,通过简单工厂产生数据库实例,调用数据库实例的insertCustomer()方法完成功能。
在简单工厂DAOFactory中,根据用户配置返回数据库的类名,通过类反射创建出类的实例。
简单工厂构造函数私有化,通过
表
关于同志近三年现实表现材料材料类招标技术评分表图表与交易pdf视力表打印pdf用图表说话 pdf
态的newInstance()方法得到实例。
ParseConfig类中的readParm(String key)方法负责从配置文件dbconfig.properties(放在src目录下)中读取指定key的值。
用户只须修改配置文件中的使用数据库类型,即可更改使用的数据库类型。无须修改main方法(客户端)。
如果增加一种数据类型,只须新建一个类,实现CustomerDAO接口,实现其中的insertCustomer()方法,并修改配置文件即可使用,将变化所须做的修改最小化。
部分代码:
CustomerDAO接口:
package com.lxt008.dao;
public interface CustomerDAO { void insertCustomer(); }
MySQLDAO类:
package com.lxt008.dao; public class MySQLDAO implements CustomerDAO{
public void insertCustomer() { System.out.println("MySQL Insert!!!"); }
}
简单工厂DAOFactory:
package com.lxt008.util; import com.lxt008.dao.CustomerDAO;
import com.lxt008.dao.MySQLDAO;
import com.lxt008.dao.OracleDAO; import com.lxt008.dao.SQLServerDAO; public class DAOFactory {
private DAOFactory() { }
static DAOFactory factory=null; public static DAOFactory newInstance() {
if(factory==null) { factory=new DAOFactory();
} return factory; }
public CustomerDAO createDAO()
{ CustomerDAO customerDAO=null; ParseConfig parseConfig=new ParseConfig();
String dao_impl_class= parseConfig.readParm("dao_impl_class"); try { customerDAO=(CustomerDAO)Class.forName(dao_impl_class).newInstance();
} catch (InstantiationException e) { e.printStackTrace(); } catch (IllegalAccessException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) { e.printStackTrace(); }
return customerDAO; } }
读取配置文件类ParseConfig
package com.lxt008.util;
import java.io.IOException;
import java.util.Properties;;
public class ParseConfig {
public String readParm(String key)
{
Properties properties=new Properties();
try {
properties.load(this.getClass().getResourceAsStream("/dbconfig.properties"));
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
String dbType=properties.getProperty(key);
return dbType;
}
}
main()方法:
package com.lxt008.service;
import com.lxt008.dao.CustomerDAO; import com.lxt008.dao.MySQLDAO; import com.lxt008.dao.OracleDAO;
import com.lxt008.util.DAOFactory; import com.lxt008.util.ParseConfig; public class Main {
/**
* @param args */ public static void main(String[] args) {
//OracleDAO oracleDAO=new OracleDAO(); //oracleDAO.insertCustomer(); //MySQLDAO mysql=new MySQLDAO();
//mysql.insertCustomer(); //ParseConfig parseConfig=new ParseConfig(); //String db= parseConfig.readDbType(); //System.out.println(db);
CustomerDAO customerDAO=DAOFactory.newInstance().createDAO(); customerDAO.insertCustomer(); }
}
配置文件dbconfig.properties
dao_impl_class=com.lxt008.dao.MySQLDAO