定义:
简单工厂模式是由一个工厂对象决定创建出哪一种产品类的实例。
讲解:
简单工厂模式作为入门级的设计模式,并未收录在GoF的23种设计模式之中。然而在其23种设计模式中总会看到简单工厂模式的影子,所以笔者有必要在这里介绍一下。
类图:
角色:
工厂类(Creator):具体类,提供一个静态的方法来创建产品。
抽象产品(Product):接口或抽象类,抽象出产品共有的方法。
具体产品(ConcreteProduct):具体类,实现抽象产品类,实现符合自身特点的方法。
代码:
//JDBC接口
public abstract interface IJdbcSql {
public abstract Connection getConnection();
}
//Mysql实现类
public class MysqlImpl implements IJdbcSql {
public Connection getConnection(){
Connection conn = null;
String url = "jdbc:mysql://127.0.0.1:3306/JMASTER?useUnicode=true&characterEncoding=UTF-8";
Class.forName("com.mysql.jdbc.Driver").newInstance();
conn = DriverManager.getConnection(url, "jmaster", "123456");
return conn;
}
}
//Oracle实现类
public class OracleImpl implements IJdbcSql {
public Connection getConnection(){
Connection conn = null;
String url = "jdbc:oracle:thin:@127.0.0.1:1521:JMASTER";
Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
conn = DriverManager.getConnection(url, "jmaster", "123456");
return conn;
}
}
//SqlServer实现类
public class SqlServerImpl implements IJdbcSql {
public Connection getConnection(){
Connection conn = null;
String url = "jdbc:microsoft:sqlserver://127.0.0.1:1433;DatabaseName=JMASTER";
Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver").newInstance();
conn = DriverManager.getConnection(url, "jmaster", "123456");
return conn;
}
}
//工厂类
public final class JdbcFactory {
public static IJdbcSql getJdbcSql(String databaseType) {
IJdbcSql jdbcSql = null;
if ("MYSQL".equals(databaseType))//Mysql
jdbcSql = new MysqlImpl();
else if ("ORACLE".equals(databaseType))//Oracle
jdbcSql = new OracleImpl();
else if ("SQLSERVER".equals(databaseType)) {//SqlServer
jdbcSql = new SqlServerImpl();
}
return jdbcSql;
}
}
注意:本例中IJdbcSql接口省略了数据库的增、删、改、查等相关接口方法。
好处:
- 符合依赖倒转原则(面向接口编程),把具体产品抽象成抽象产品类或抽象接口类。
- 符合部分开闭原则(对扩展开放,对修改关闭),为什么说是部分,因为如果要增加新的产品,只需要实现接口即可。但是要使用新增加的产品,则需要修改工厂类。简单工厂模式只做到了对扩展开发,未做到对修改关闭。
使用场景:
- 创建具有相同行为特征的产品对象。
- 具体产品的数量不会频繁的发生变化。
总结:
简单工厂模式,作为创建型设计模式,把创建具体产品的细节封装起来,只对外部提供创建产品的方法。不直接依赖于具体产品,而是依赖于工厂类,降低了耦合。同时对扩展进行开放,但是未对修改关闭。