一 概念:
简单工厂模式就是通过一个工厂类根据参数动态创建对应的类。
二 案例
我们以汽车作为例子,在现实生活中汽车只是一个抽象的产品,其中有很多类型的汽车才是具体产品,如奔驰、宝马、保时捷等等(当然每个品牌下还有各种版本,这就不做讨论了,假设每个品牌就对应一种车)。简单类图如下:
当我们去综合类型的店买车要试开车时,销售员可能最简单直接的方法就是直接拿出他们最畅销的车子出来让你试驾。简易代码如下:
public class CarTest {
public static void main(String[] args) {
BenzCar car = new BenzCar();
car.driver();
}
}
如果你想试驾宝马车时就如上面代码,会直接拿出该品牌的车。然而当客户想换品牌的时候,就得重新改客户端代码然后在重新new出对应的车来,这样就非常麻烦。
然而简单工厂就可以解决这个问题,把所有车的品牌统计出来,我们只要传入品牌这个参数就可以创建相应车的实例,这样就可避免客户每次换车的时候都要重新改代码。如下
1 public class CarFactory {
2 /**
3 * @description 汽车工厂方法,根据汽车品牌类型创建对应车的实例
4 * @param type 品牌
5 * @return
6 * @author YuanFY
7 * @date 2017年8月5日 上午11:22:53
8 * @version 1.0
9 */
10 public static Car newCar(String type) {
11 switch (type) {
12 case "Benz":
13 return new BenzCar();
14 case "BMW":
15 return new BenzCar();
16 case "Porsche":
17 return new BenzCar();
18 default:
19 return new Car();
20 }
21 }
22 }
23 public class CarTest {
24
25 public static void main(String[] args) {
26 Car car = CarFactory.newCar("Benz");
27 car.driver();
28 }
29 }
针对这种需求通过简单工厂方法还是方便的。(感觉这个例子有点勉强,希望各位能懂)
三 优缺点
优点:优化了客户端的代码,明确了各自的职责和权力,其中工厂类是整个模式的关键。
缺点:工厂类集中了所有实例的创建逻辑,它所能创建的类只能是事先考虑到的,如果需要添加新的类,则就需要改变工厂类了。当系统中的具体产品类不断增多时候,可能会出现要求工厂类根据不同条件创建不同实例的需求.这种对条件的判断和对具体产品类型的判断交错在一起,很难避免模块功能的蔓延,对系统的维护和扩展非常不利;
这就是本该拼搏的年纪,却想得太多,做得太少!