首页 > 代码库 > 设计模式学习--Factory Method

设计模式学习--Factory Method

What

Factory Method:定义一个创建对象的接口,让子类来决定实例化哪一个类。Factory Method使一个类的实例化延迟到其子类。

Why

Factory Method是一个比较基础的创建型模式,它主要在于由子类决定实例化哪一个类。主要用于框架代码或者工具包中。
适用于如下场景:
1、当一个类不知道它所必须创建的对象的类的时候
2、当一个类希望由子类来指定它所创建对象的时候
3、当类将创建对象的职责委托给多个帮助子类的某一个,并且你希望将哪一个帮助子类是代理者这一信息局部化的时候

How

假设如下场景,写一个语法分析器,需要支持C与java代码的语法分析,需要完成代码语法检查和语法解析工作。以此为例实现工厂模式。
语法分析器接口

public interface Parsing {

    void checkGrammar();

    void parseCode();
}

C代码语法分析器实现

public class CParsing implements Parsing {

    @Override
    public void checkGrammar() {
        System.out.println("check c grammar");
    }

    @Override
    public void parseCode() {
        System.out.println("parse c code");
    }
}

Java代码语法分析器实现

public class JavaParsing implements Parsing {

    @Override
    public void checkGrammar() {
        System.out.println("check java grammar");
    }

    @Override
    public void parseCode() {
        System.out.println("parse java code");
    }
}

解析器工厂接口

public interface ParsingFactory {

    Parsing createParsing();
}

C代码解析器工厂实现

public class CParsingFactory implements ParsingFactory {

    @Override
    public Parsing createParsing() {
        return new CParsing();
    }
}

Java代码解析器工厂实现

public class JavaParsingFactory implements ParsingFactory {

    @Override
    public Parsing createParsing() {
        return new JavaParsing();
    }
}

客户端调用

public class App {

    public static void main( String[] args ){
        ParsingFactory factory=new CParsingFactory();
        Parsing parsing=factory.createParsing();
        parsing.checkGrammar();
        parsing.parseCode();

        ParsingFactory factory1=new JavaParsingFactory();
        Parsing parsing1=factory1.createParsing();
        parsing1.checkGrammar();
        parsing1.parseCode();
    }
}

以上示例类图如下:


Discuss

Abstarct Factory VS Factory Method
在学习Factory Method就对Factory Method模式和Abstarct Factory很迷惑,经过反复阅读两个章节,基本上总结出了两者的一个联系,Abstarct Factory是一个特殊的Factory Method,但是两者区别在哪呢?
完成Factory Method的示例发现,在Abstract Factory中示例的UML和Factory Method的示例的UML是结构是一样的,于是就思考为什么?
两者的意图如下:
Factory Method:定义一个创建对象的接口让子类来决定实例化哪一个类。Factory Method使一个类的实例化延迟到其子类
Abstarct Factory:提供一个创建一系列相关或相互依赖的接口,而无需指定他们具体类。
从以上粗体部分就可以体现其区别的地方。
1.Abstarct Factory强调的是创建一系列相关相互依赖的接口,也就是Abstarct这个工厂可以生产一系列的对象,是一个一对多的关系,然后我又重新考虑了一下,Abstarct Factory的示例,并进行了完善(详情见:设计模式学习--Abstarct Factory的ChangeLog)。它的扩展性侧重横向扩展。比如在Abstarct Factory学习中的例子,我们又来一个RoleDao,我们是在DaoFactory中增加createRoleDao方法。
2.Factory Method强调的是创建一个对象接口,让子类来决定实例化哪一个类,也就是它的工厂和产品是一对一的关系。它的扩展性侧重的是垂直扩展,比如本节的示例,我们需要增加一个支持Sql语言的语法分析器,我需要增加一个SqlParsingFactory类和一个SqlParsing类。
关于Abstarct Factory VS Factory Method的讨论还有如下可以参考:
http://www.cnblogs.com/happyhippy/archive/2010/09/26/1836223.html
http://www.cnblogs.com/procoder/archive/2009/04/24/1442920.html