欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

设计模式回顾系列之简单工厂模式

程序员文章站 2022-10-20 08:26:38
简单工厂模式,需要说明的是,它并不属于GOF 23种设计模式中的一种。但它却丰富了工厂模式家族,因为其简单的思想和使用方式,也有很广泛的使用 简单工厂模式又称为静态工厂模式,它用来确定创建哪一种对象的实例。这种模式应该说是最简单最实用的工厂模式了,它将外界创建对象的逻辑收集起来,做到了对外界隔离对象 ......

简单工厂模式,需要说明的是,它并不属于gof 23种设计模式中的一种。但它却丰富了工厂模式家族,因为其简单的思想和使用方式,也有很广泛的使用

简单工厂模式又称为静态工厂模式,它用来确定创建哪一种对象的实例。这种模式应该说是最简单最实用的工厂模式了,它将外界创建对象的逻辑收集起来,做到了对外界隔离对象的创建逻辑的目的,使外面完全的成为了对象实例的使用者,明确了职责。

不过这种模式也有着非常明显是的缺点,工厂类中集中了所有对象实例的创建逻辑,造成了功能的高内聚;另外在扩展方面,如果需要添加新的类,就需要改变工厂类。随着系统功能的增多,工厂类也会变得很臃肿。

使用注意

  • 尽量不要用于创建太多的对象,因为这样会把业务逻辑变得复杂,也会让系统耦合度变高,很容易造成全局性的影响
  • 客户端只关心获取对象,而不关心对象的创建细节的时候

另外简单工厂模式与策略者模式在结构上也非常的相似,在某些场景两者几乎可以互换。但是需要强调的是,简单工厂模式处理的是对象的获取,策略者模式处理的是算法及其行为的抽象。

该模式中包含的角色及其职责

  • 工厂(factory)角色 :简单工厂模式的核心,它负责实现创建所有实例的内部逻辑。工厂类可以被外界直接调用,创建所需的产品对象。
  • 抽象产品(product)角色 :简单工厂模式所创建的所有对象的父类,它负责描述所有实例所共有的公共接口。
  • 具体产品(concrete product)角色:是简单工厂模式的创建目标,所有创建的对象都是充当这个角色的某个具体类的实例。

以下为简单工厂的uml类图

  设计模式回顾系列之简单工厂模式

下面将展示一个简单的计算器列子,使用了抽象类,是因为抽象类比接口可以更好地表达实例对象的内容

先来看一下这个实例的类图,calulator为计算器加减乘除的抽象类,目前只提供了一个方法就是计算算术结果,simplefactory类专用于用于生产加减乘除实例的对象

设计模式回顾系列之简单工厂模式

以下为具体的代码

 

 1    public abstract class calculator
 2     {
 3         public abstract int operate(int a,int b);
 4     }
 5 
 6     public class minus: calculator
 7     {
 8         public override int operate(int a, int b)
 9         {
10             return a- b;
11         }
12     }
13 
14     public class plus : calculator
15     {
16         public override int operate(int a, int b)
17         {
18             return a + b;
19         }
20     }
21 
22     public class multiply : calculator
23     {
24         public override int operate(int a, int b)
25         {
26             return a * b;
27         }
28     }
29 
30     public class divide : calculator
31     {
32         public override int operate(int a, int b)
33         {
34             if(b==0) throw new argumentexception("除数不能为0");
35             return a / b;
36         }
37     }

这里是工厂化处理

 1     public class simplefactory
 2     {
 3         public calculator getoperation(string operatorname)
 4         {
 5             switch (operatorname)
 6             {
 7                 case "minus":
 8                     return new minus();
 9 
10                 case "plus":
11                     return new plus();
12 
13                 case "multiply":
14                     return new multiply();
15 
16                 case "divide":
17                     return new divide();
18                 
19                 default:
20                     throw new exception("当前未提供此计算方式");
21             }
22         }
23     }

调用

 1   class program
 2     {
 3         static void main(string[] args)
 4         {
 5             simplefactory simplefactory = new simplefactory();
 6 
 7             dictionary<string,string> optionsdictionary = new dictionary<string, string>
 8             {
 9                 { "a","plus"},
10                 { "b","minus"},
11                 { "c","multiply"},
12                 { "d","divide"},
13             };
14 
15             string readoptions = string.empty;
16 
17 
18             do
19             {
20                 foreach (keyvaluepair<string, string> keyvaluepair in optionsdictionary)
21                 {
22                     console.writeline(keyvaluepair.key+"、"+keyvaluepair.value);
23                 }
24 
25                 console.writeline("请输入a、b、c、d确定计算方式");
26                 string option = console.readline();
27                 if (!optionsdictionary.containskey(option))
28                 {
29                     throw new exception("当前未提供此计算方式");
30                 }
31 
32                 console.writeline("请输入第一个数");
33                 int a = convert.toint32(console.readline());
34                 console.writeline("请输入第二个数");
35                 int b = convert.toint32(console.readline());
36 
37                 calculator calculator = simplefactory.getoperation(optionsdictionary[option]);
38                 console.writeline("当前结果是:"+calculator.operate(a, b));
39 
40                 console.writeline("继续请按y");
41 
42                 readoptions = console.readline();
43 
44             } while (readoptions == "y");
45         }
46     }

 下面是输出结果

 1 a、plus
 2 b、minus
 3 c、multiply
 4 d、divide
 5 请输入a、b、c、d确定计算方式
 6 a
 7 请输入第一个数
 8 1
 9 请输入第二个数
10 5
11 当前结果是:6
12 继续请按y
13 y
14 a、plus
15 b、minus
16 c、multiply
17 d、divide
18 请输入a、b、c、d确定计算方式
19 c
20 请输入第一个数
21 9
22 请输入第二个数
23 2
24 当前结果是:18
25 继续请按y