设计模式之简单工厂(sample Factory)模式

来源:互联网 发布:网络盗刷犯罪侦破 编辑:程序博客网 时间:2024/06/07 16:07
 
 
工厂模式是我们最常用的模式了,为什么工厂模式是如此常用?因为工厂模式就相当于创建实例对象的new,我们经常要根据类Class生成实例对象,如A a=new A() 工厂模式也是用来创建实例对象的,所以以后new时就要多个心眼,是否可以考虑使用工厂模式,虽然这样做,可能多做一些工作,但会给你系统带来更大的可扩展性和尽量少的修改量。
我们以类Sample为例, 如果我们要创建Sample的实例对象:
Sample sample=new Sample();
可是,实际情况是,通常我们都要在创建sample实例时做点初始化的工作,比如赋值 查询数据库等。
首先,我们想到的是,可以使用Sample的构造函数,这样生成实例就写成:
Sample sample=new Sample(参数);
但是,如果创建sample实例时所做的初始化工作不是像赋值这样简单的事,可能是很长一段代码,如果也写入构造函数中,那你的代码很难看了(就需要Refactor重整)。
为什么说代码很难看,初学者可能没有这种感觉,我们分析如下,初始化工作如果是很长一段代码,说明要做的工作很多,将很多工作装入一个方法中,相当于将很多鸡蛋放在一个篮子里,是很危险的,这也是有背于Java面向对象的原则,面向对象的封装(Encapsulation)和分派(Delegation)告诉我们,尽量将长的代码分派“切割”成每段,将每段再“封装”起来(减少段和段之间耦合联系性),这样,就会将风险分散,以后如果需要修改,只要更改每段,不会再发生牵一动百的事情。
在本例中,首先,我们需要将创建实例的工作与使用实例的工作分开, 也就是说,让创建实例所需要的大量初始化工作从Sample的构造函数中分离出去。
 
 
 
抽象工厂
工厂模式中有: 工厂方法(Factory Method) 抽象工厂(Abstract Factory).
这两个模式区别在于需要创建对象的复杂程度上。如果我们创建对象的方法变得复杂了,如上面工厂方法中是创建一个对象Sample,如果我们还有新的产品接口Sample2.
这里假设:Sample有两个concrete类SampleA和SampleB,而Sample2也有两个concrete类Sample2A和Sample2B
那么,我们就将上例中Factory变成抽象类,将共同部分封装在抽象类中,不同部分使用子类实现.
 
 
//实例代码:简单计算器实现

#include "stdafx.h"
#include <string.h>
using namespace std;
enum Op_Type
{
 Op_Add = 0,
 Op_Sub = 1,
 Op_Nul = 2,
 Op_Div = 3
};
class Myoperator
{
public:
 Myoperator()
 {
  result = 0;
  numA = numB = 0;
 }
 virtual ~Myoperator()
 {

 }
 virtual double  getResult()
 {
   result = 0;
  return result;
 }
 //检测输入的字符是否合法
  static string checkNumberInput(string currentNumber, string inputString)
 {
  string result = "";
  if (inputString == ".")
  {
   
   if (strstr(result.c_str(),".")==NULL)
   {
    if (currentNumber.size() == 0)
     result = "0" + inputString;
    else
     result = currentNumber + inputString;
   }
  }
  else if (currentNumber == "0")
  {
   result = inputString;
  }
  else
  {
   result = currentNumber + inputString;
  }

  return result;
 }
 double getNumA()
 {
  return numA;
 }
 double getNumB()
 {
  return numB;
 }
protected:
 double numA;
 double numB;
 double result;
private:
 
};

class operatorAdd : public Myoperator
{
public:
 virtual double getResult()
 {
  result = numA+numB
  return result;
 }
protected:
private:
};
class operatorSub : public Myoperator
{
public:
 virtual double getResult()
 {
  result = numA-numB
   return result;
 }
protected:
private:
};
class operatorNul : public Myoperator
{
public:
 virtual double getResult()
 {
  result = numA*numB
   return result;
 }
protected:
private:
};
class operatorDiv : public Myoperator
{
public:
 virtual double getResult()
 {
  ASSERT(numB!=0)
  result = numA/numB
   return result;
 }
protected:
private:
};
class operatorFactory
{
public:
 operatorFactory()
 {
  m_op = NULL;
 }
 ~operatorFactory()
 {
  delete m_op;
  m_op = NULL;
 }
 Myoperator* createOperate(Op_Type o_type)
 {
  switch (o_type)
  {
  case Op_Add:
   m_op = new operatorAdd();
   break;
  case Op_Sub:
   m_op = new operatorSub();
   break;
  case Op_Nul:
   m_op = new operatorNul();
   break;
  case Op_Div:
   m_op = new operatorDiv();
   break;
  }
  return m_op;
 }
protected:
private:
 Myoperator*m_op;
};

int _tmain(int argc, _TCHAR* argv[])
{
 operatorFactory*m_opFac = new operatorFactory();
 Myoperator*m_op = m_opFac->createOperate(Op_Nul);

//...........................

 return 0;
}

原创粉丝点击