zoukankan      html  css  js  c++  java
  • 简单工厂的来世今生

        今天,和一哥们讨论到简单工厂,正好我也对此关注了很长时间,所以有感而发,写点东西,供以后回味这段历史。
        

        简单工厂的用途在现代语言(具有运行时强类型系统支持的语言,如Java,.Net),确实用途不大,感觉不到想起他模式一样重要,但是在不具备运行时强类型系统支持的语言(如C/C++等,C++具有编译时的强类型,运行时没有),这是一个极其重要的模式。
        比如一个简单的需求,我需要根据一个名称来确定最终使用的实现,如数据库的连接
        IConnect <--SqlConnect
                       <-OracalConnect
                       <-......
        我需要在配置文件里确定最终使用哪个。
        在现代语言里,可以直接存储一个类型名,运行时可以使用这个名字反射到类型,然后用类型反射出具体的实例
        如下所示,用类似C#的代码描述,假设配置文件里有如下配置:
        <appSettings>
        <add key="ConnectType" value="OracalConnect"/>
        </appSettings>
        在程序里如下代码即可实现具体连接的选择:
        Type t=Type.GetType(ApplicationSetting["ConnectType"]);
        IConnect con=Activitor.CreateInstance(t) as IConnect;
        DoSomeThing(con);
      

         但是,在以前的语言里,运行系统里没有"类型"这么一个概念,更加没有"反射"的概念,这时候,简单工厂就基本上成了必须的模式了,只能老老实实地手动写一个简单工厂,大概如下:
         class ConnectFac
         {
                  public:
                  static IConnect* CreateConnect(string type)
                  {
                       if(type=="SqlConnect")return new SqlConnect();
                        if(type=="OracalConnect")return new OracalConnect();
                        return NULL;
                  }
         }
         然后再程序里如下,可以完成全面等同的功能
                 point_ptr<IConnect*> con= CreateConnect(ApplicationSetting["ConnectType"]);
                 DoSomeThing(con);
        
         所以,正如GOF中的Flower所说,语言在进步,很多模式已经集成到语言本身里面,成了语言的一部分。
        

         我的结论是:工厂方法很有用,但在现代语言里,没有必要手工去实现了,但偶尔还是用得上的:)

  • 相关阅读:
    编写高性能Web应用程序的10个入门技巧
    C#中class与struct的区别[转]
    web架构设计经验分享 (转)
    NUnit入门篇
    sqlserver 重建日志文件
    ExecuteReader如何取得输出参数和返回值
    防止表单重复提交的几种方案
    Web 2.0 versus Virtual Worlds (转)
    ActionScript 3.0 Step By Step系列(七):使用XML和XMLList类处理XML数据 (转)
    PlayButton Component
  • 原文地址:https://www.cnblogs.com/stst/p/4908547.html
Copyright © 2011-2022 走看看