工厂模式
简介
这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。
在工厂模式中,我们在创建对象时不会对客户端暴露创建逻辑,并且是通过使用一个共同的接口来指向新创建的对象。
应用实例
1、您需要一部手机,可以直接从工厂里面提货,而不用去管这部手机是怎么做出来的,以及这个手机里面的具体实现
优点
一个调用者想创建一个对象,只要知道其名称就可以了。
扩展性高,如果想增加一个产品,只要扩展一个工厂类就可以。
屏蔽产品的具体实现,调用者只关心产品的接口。
缺点
每次增加一个产品时,都需要增加一个具体类和对象实现工厂,使得系统中类的个数成倍增加,在一定程度上增加了系统的复杂度,同时也增加了系统具体类的依赖。这并不是什么好事。
使用场景
1、日志记录器:记录可能记录到本地硬盘、系统事件、远程服务器等,用户可以选择记录日志到什么地方。
2、数据库访问,当用户不知道最后系统采用哪一类数据库,以及数据库可能有变化时。
3、设计一个连接服务器的框架,需要三个协议,"POP3"、"IMAP"、"HTTP",可以把这三个作为产品类,共同实现一个接口。
实现(图例)
代码实现
interface
public interface Phone {
// 生产手机的模型
void show();
}
class 华为手机
public class HuaWei implements Phone {
@Override
public void show() {
// 生产手机的核心步骤都在这个类内
System.out.println("生产了一部华为手机");
}
}
class 小米手机
public class XiaoMi implements Phone {
@Override
public void show() {
// 生产手机的核心步骤都在这个类内
System.out.println("生产了一部小米手机");
}
}
class 苹果手机
public class IPhone implements Phone {
@Override
public void show() {
System.out.println("生产了一部苹果手机");
}
}
工厂
public class Factory {
public Phone getPhone(String phoneType) {
if (phoneType == null) {
return null;
} else if (phoneType.equalsIgnoreCase("HuaWei")) {
return new HuaWei();
} else if (phoneType.equalsIgnoreCase("XiaoMi")) {
return new XiaoMi();
} else if (phoneType.equalsIgnoreCase("IPhone")) {
return new IPhone();
}
return null;
}
}
使用工厂
public class FactoryTest {
public static void main(String[] args) {
Factory factory = new Factory();
Phone phon1 = factory.getPhone("XiaoMi");
phon1.show();
Phone phon2 = factory.getPhone("IPhone");
phon2.show();
Phone phon3 = factory.getPhone("HuaWei");
phon3.show();
}
}
输出结果:
小结
可见实例化不同手机类,不再关心需要多少初始化参数,例如手机型号,电池容量,尺寸等,
只需要关注调用接口。
如果再增加一个品牌,则需要在定义一个类,并且增加对象实现工厂(麻烦)