zoukankan      html  css  js  c++  java
  • 简单工厂

    简单工厂模式根据提供的数据或者参数返回几个可能的类中的一个实例,说通俗点有点像面向对象编程中的多态性,一个基类,有多个派生类,在另外的调用程序中,根据参数来决定返回这个基类的哪个具体的派生类,返回值为基类类型,因为基类的引用可以指向派生类对象,而且这些所有的派生类都包含有基类的函数,也就是说派生类中有相同的函数,但是函数的实现可能不同。

    在简单工厂模式中,通常其返回的所有的类都有一个共同的基类和一些共同的方法,不过每一个类都完成不同的功能,并针对不同的数据类型做了不同的优化。简单工厂模式实际上并不是23个常用设计模式之一,但是也算是设计模式的简单入门,对以后的学习有比较大的帮助。

    简单的理解,简单工厂模式更多的使用了面向对象编程中的多态性,基类的引用可以指向派生类,并且调用派生的方法,即多态性。

    假定X是一个基类,XY和XZ都是派生于X的派生类,XFactory类中根据提供给它的参数来决定返回XY或者 类的哪一个,返回的是哪个类的实例对于编程者来说并不是那么重要,因为这些类有着相同的方法,编程者需要做的就是通过基类引用直接调用方法,不用去关心到底返回的是哪个派生类,因为这些类有相同的方法,只是实现不同而已。如何决定返回哪一个派生类,取决于工厂的设计,该方法可以是非常复杂的函数,也可以是简单的函数。

     假设我们有一个类,用来存放名字,其中包含名字的姓和名分别存放。这个类的基本代码如下:

    复制代码
    using System;  
    02.  
    03.namespace NameFactory  
    04.{  
    05.    /// <summary>  
    06.    /// Summary description for Namer.  
    07.    /// </summary>  
    08.    //Base class for getting split names  
    09.    public class Namer  {  
    10.        //parts stored here  
    11.        protected string frName, lName;  
    12.          
    13.        //return first name  
    14.        public string getFrname(){  
    15.            return frName;  
    16.        }  
    17.        //return last name  
    18.        public string getLname() {  
    19.            return lName;  
    20.        }  
    21.    }  
    22.}  
    

      

    在这个类中可以分别返回名和姓。protected string frName, lName;两个受保护的变量可以被派生类继承。

    现在我们派生两个非常简单的派生类,并在派生类中把姓名分割成两个部分。如果是姓在前,名在后,中间用空格分开,责是FirstFirst类,如果是姓在后,名在前,中间用“,”分开,则是LastFirst类。两个类的设计分别为:

    复制代码
    using System;  
    02.  
    03.namespace NameFactory  
    04.{  
    05.    /// <summary>  
    06.    /// Summary description for FirstFirst.  
    07.    /// </summary>  
    08.    public class FirstFirst : Namer  
    09.    {  
    10.        public FirstFirst(string name)  
    11.        {  
    12.            int i = name.IndexOf (" ");  
    13.            if(i > 0) {  
    14.                frName = name.Substring (0, i).Trim ();  
    15.                lName = name.Substring (i + 1).Trim ();  
    16.            }  
    17.            else {  
    18.                lName = name;  
    19.                frName = "";  
    20.            }  
    21.        }  
    22.    }  
    23.}  
    复制代码
    复制代码
    using System;  
    02.  
    03.namespace NameFactory  
    04.{  
    05.    /// <summary>  
    06.    /// Summary description for LastFirst.  
    07.    /// </summary>  
    08.    public class LastFirst : Namer  
    09.    {  
    10.        public LastFirst(string name)       {  
    11.            int i = name.IndexOf (",");  
    12.            if(i > 0) {  
    13.                lName = name.Substring (0, i);  
    14.                frName = name.Substring (i + 1).Trim ();  
    15.            }  
    16.            else {  
    17.                lName = name;  
    18.                frName = "";  
    19.            }  
    20.        }  
    21.    }  
    22.}  
    复制代码
    两个派生类中构造函数根据是不是有“,”来将名字中的姓和名分割开来,分别保存的对应的变量中。
    
    然后我们就可以构建简单的工厂了,只需要检测逗号的存在,然后返回两个类中的一个就可以了。
    
    复制代码
    using System;  
    02.  
    03.namespace NameFactory  
    04.{  
    05.    /// <summary>  
    06.    /// Summary description for NameFactory.  
    07.    /// </summary>  
    08.    public class NameFactory    {  
    09.        public NameFactory() {}  
    10.  
    11.        public Namer getName(string name) {  
    12.            int i = name.IndexOf (",");  
    13.            if(i > 0)  
    14.                return new LastFirst (name);  
    15.            else  
    16.                return new FirstFirst (name);  
    17.        }  
    18.    }  
    19.}  
    复制代码
    

      

  • 相关阅读:
    Android Widget小组件开发(一)——Android实现时钟Widget组件的步骤开发,这些知识也是不可缺少的!
    java基础——static keyword小节
    iOS UI08_UITableView
    Android 6.0 开发人员对系统权限的使用与练习(Permissions Best Practices)
    Android简单实现BroadCastReceiver广播机制
    UI组件之TextView及其子类(一)TextView和EditText
    BZOJ 3112 [Zjoi2013]防守战线 线性规划
    反射 + 配置文件 实现IOC容器
    android:异步任务asyncTask介绍及异步任务下载图片(带进度条)
    【LeetCode-面试算法经典-Java实现】【058-Length of Last Word (最后一个单词的长度)】
  • 原文地址:https://www.cnblogs.com/dongyuhan/p/6599771.html
Copyright © 2011-2022 走看看