设计模式(2)之工厂方法模式

来源:互联网 发布:知乎怎么私信匿名用户 编辑:程序博客网 时间:2024/05/20 16:46

1. 什么是工厂方法模式

工厂方法模式同样属于类的创建型模式又被称为多态工厂模式 。工厂方法模式的意义是定义一个创建产品对象的工厂接口,将实际创建工作推迟到子类当中。核心工厂类不再负责产品的创建,这样核心类成为一个抽象工厂角色,仅负责具体工厂子类必须实现的接口,这样进一步抽象化的好处是使得工厂方法模式可以使系统在不修改具体工厂角色的情况下引进新的产品。

2. 工厂方法模式中包含的角色及其职责

<1> 抽象工厂(Creator)角色 工厂方法模式的核心,任何工厂类都必须实现这个接口。

<2> 具体工厂( Concrete Creator)角色 具体工厂类是抽象工厂的一个实现,负责实例化产品对象。

<3> 抽象(Product)角色 工厂方法模式所创建的所有对象的父类,它负责描述所有实例所共有的公共接口。

<4> 具体产品(Concrete Product)角色 工厂方法模式所创建的具体实例对象

3. 工厂方法模式和简单工厂模式比较

工厂方法模式与简单工厂模式在结构上的不同不是很明显。工厂方法类的核心是一个抽象工厂类,而简单工厂模式把核心放在一个具体类上。

工厂方法模式之所以有一个别名叫多态性工厂模式是因为具体工厂类都有共同的接口,或者有共同的抽象父类。

当系统扩展需要添加新的产品对象时,仅仅需要添加一个具体对象以及一个具体工厂对象,原有工厂对象不需要进行任何修改,也不需要修改客户端,很好的符合了“开放-封闭”原则。而简单工厂模式在添加新产品对象后不得不修改工厂方法,扩展性不好。

工厂方法模式退化后可以演变成简单工厂模式。

总之,工厂方法模式就是将简单工厂模式中的工厂类变成工厂接口,再派生具体的工厂类创建相对应的实例对象。好处就是,当需要添加新的对象时,不需要修改工厂接口,只需要派生相应的工厂类即可。

下面看代码:

//FruitFactory.java//工厂接口public interface FruitFactory {    public  Fruit getFruit();}
//Fruit.java//所有实例对象的接口public interface Fruit {    public void get();}
//Apple.java//苹果类public class Apple implements Fruit{    public void get(){        System.out.println("采集苹果");    }}
//Banana.java //香蕉类public class Banana implements Fruit{    public void get(){        System.out.println("采集香蕉");    }}
//AppleFactory.java//苹果工厂public class AppleFactory implements FruitFactory {    @Override    public Fruit getFruit() {        return new Apple();    }}
//BananaFactory.java//香蕉工厂public class BananaFactory implements FruitFactory {    @Override    public Fruit getFruit() {        return new Banana();    }}

现在添加一个 Pear类,很简单,直接写一个创建Pear的工厂类即可。

//Pear.java//梨类public class Pear implements Fruit {    @Override    public void get() {        System.out.println("采集梨子");    }}
//PearFactory.java//梨子类public class PearFactory implements FruitFactory {    @Override    public Fruit getFruit() {        // TODO Auto-generated method stub        return new Pear();    }}
//MainClass.java//主类public class MainClass {    public static void main(String[] args) {        FruitFactory appleFactory = new AppleFactory();        Fruit apple = appleFactory.getFruit();        FruitFactory banaFactory = new BananaFactory();        Fruit banana =  banaFactory.getFruit();        apple.get();        banana.get();        // 新增Pear类        FruitFactory pearFactory = new PearFactory();        Fruit pear = pearFactory.getFruit();        pear.get();    }}
0 0