定义:抽象工厂模式(Abstract Factory),提供一个创建一系列相关或相互依赖对象的接口,而无需要指定它们具体的类。
类型:创建型模式。
类图:
参与角色:
1. FeaturePhone、SmartPhone,分别是功能手机和智能手机的两个抽象类,分别抽象出来了功能机的制造流程,智能机的制造流程。
2. NokiaFeaturePhone、SamsungFeaturePhone,分别实现了功能机的制造流程。
3. NokiaSmartPhone、SamsungSamrtPhone,分别实现了智能机的生产制造流程。
4. Factory,抽象工厂,即手机生产厂所必须具备的基本要求都抽象出来了。
5. NokiaFactory,根据Nokia手机生产的要求,在已经建设好的抽象工厂上完成了Nokia功能机以及智能机生产的基本要求。
6. SamsungFactory,根据Samsung手机生产的要求,在已经建设好的抽象工厂上完成了Samsung功能机和智能机生产的工厂基本要求。
概述:
随着科技的发展,手机越来越强大,智能手机(Smart Phone)越来越普及,而传统的功能手机(Feature Phone)销量在进一步下滑。各家手机生产商都在裁剪功能手机的生产线,但是手机生产线能够减少,厂房却不能减少。为了节约成本,代工厂决定将Nokia的手机放在一个工厂里生产,Samsung手机放在另外一个工厂里生产。这样就不用再新建工厂了,工厂的利用率得到提升。
抽象工厂模式就是为了解决这一问题而产生的。当不同的产品越来越多时,如果给每个产品新建一个工厂,会显得很浪费,并且如果工厂过多,管理工厂本身也会成为一个问题。这个时候,一系列比较有共性的产品共用一个工厂是个比较好的选择。将已经改造好的Nokia功能手机以及智能手机生产线,直接对接到已经根据要求改造过的Nokia手机生产厂就可以直接生产Nokia功能机以及智能机了。
代码:
1 #include <iostream>
2 #include <afxcom_.h>
3 using namespace std;
4
5
6 class CFeaturePhone
7 {
8 public:
9 virtual void ProducePhone() = 0;
10 };
11
12 class CSmartPhone
13 {
14 public:
15 virtual void ProducePhone() = 0;
16 };
17
18 class CNokiaFeaturePhone : public CFeaturePhone
19 {
20 public:
21 virtual void ProducePhone()
22 {
23 cout<<"Produce Nokia feature Phone."<<endl;
24 }
25 };
26
27 class CsamsungFeaturePhone : public CFeaturePhone
28 {
29 public:
30 virtual void ProducePhone()
31 {
32 cout<<"Produce Samsung feature phone."<<endl;
33 }
34 };
35
36 class CNokiaSmartPhone : public CSmartPhone
37 {
38 public:
39 virtual void ProducePhone()
40 {
41 cout<<"Produce Nokia smart phone."<<endl;
42 }
43 };
44
45 class CSamsungSmartPhone : public CSmartPhone
46 {
47 public:
48 virtual void ProducePhone()
49 {
50 cout<<"Produce Samsung smart phone."<<endl;
51 }
52 };
53
54 class CFactory
55 {
56 public:
57 virtual CFeaturePhone* CreateFeaturePhone() = 0;
58 virtual CSmartPhone* CreateSmartPhone() = 0;
59 };
60
61 class CNokiaPhoneFactory : public CFactory
62 {
63 public:
64 virtual CFeaturePhone* CreateFeaturePhone()
65 {
66 CFeaturePhone* pPhone = new CNokiaFeaturePhone();
67
68 return pPhone;
69 }
70
71 virtual CSmartPhone* CreateSmartPhone()
72 {
73 CSmartPhone* pPhone = new CNokiaSmartPhone();
74
75 return pPhone;
76 }
77 };
78
79 class CSamsungPhoneFactory : public CFactory
80 {
81 public:
82 virtual CFeaturePhone* CreateFeaturePhone()
83 {
84 CFeaturePhone* pPhone = new CsamsungFeaturePhone();
85
86 return pPhone;
87 }
88
89 virtual CSmartPhone* CreateSmartPhone()
90 {
91 CSmartPhone* pPhone = new CSamsungSmartPhone();
92
93 return pPhone;
94 }
95 };
96
97 int _tmain(int argc, _TCHAR* argv[])
98 {
99 // Nokia phone factory
100 CFactory* pNokiaFactory = new CNokiaPhoneFactory();
101 CFeaturePhone* pNokiaFeaturePhone = pNokiaFactory->CreateFeaturePhone();
102 pNokiaFeaturePhone->ProducePhone();
103 CSmartPhone* pNokiaSmartPhone = pNokiaFactory->CreateSmartPhone();
104 pNokiaSmartPhone->ProducePhone();
105
106 delete pNokiaFeaturePhone;
107 pNokiaFeaturePhone = NULL;
108 delete pNokiaSmartPhone;
109 pNokiaSmartPhone = NULL;
110 delete pNokiaFactory;
111 pNokiaFactory = NULL;
112
113 // Samsung phone factory
114 CFactory* pSamsungFactory = new CSamsungPhoneFactory();
115 CFeaturePhone* pSamsungFeaturePhone = pSamsungFactory->CreateFeaturePhone();
116 pSamsungFeaturePhone->ProducePhone();
117 CSmartPhone* pSamsungSmartPhone = pSamsungFactory->CreateSmartPhone();
118 pSamsungSmartPhone->ProducePhone();
119
120 delete pSamsungFeaturePhone;
121 pSamsungFeaturePhone = NULL;
122 delete pSamsungSmartPhone;
123 pSamsungSmartPhone = NULL;
124 delete pSamsungFactory;
125 pSamsungFactory = NULL;
126
127 return 0;
128 }
适用场合:
适用产品簇比较多,并且产品系列比较多的类型。例如某电子公司,光镍电子就有十几个系列,因为每一条镍电池生产线较小,如果每一款镍电池建一个工厂,不现实,所有镍电池生产线共用一个工厂会比较好。另外,公司不仅有镍电池系列,还有不同款式的学习机,电子辞典等许多电子产品。这样的公司就比较适合使用抽象工厂模式。
优缺点:
优点,同一系列或者相互关联的产品,可以共用工厂,而不必新建工厂,工厂的效率利用率会比较高。
缺点,如果同一系列或者相互关联的产品里又增加了新的产品,则共同的工厂需要修改来进行生产新产品,这可能会影响到原有的产品的正常生产。
参考资料:
《设计模式——可复用面向对象软件基础》
《Java与模式》
- 《大话设计模式》