专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
工厂方法(Factory Method)模式
2019-04-15 14:23
发布
生成海报
站内文章
/
PIC单片机
12338
0
1692
加入收藏
联系我们
网站搜索
首页
另类生活
.NET技术
数据库技术
JavaScript技术
网页设计相关
技术专题
项目体系
网络日志
网站论坛
放心去飞
→
项目体系
→
软件方法学
→
设计模式
工厂方法(Factory Method)模式
作者:
吕震宇
一、 工厂方法(Factory Method)模式
工厂方法(FactoryMethod)模式是类的创建模式,其用意是定义一个创建产品对象的工厂接口,将实际创建工作推迟到子类中。工厂方法模式是简单工厂模式的进一步抽象和推广。由于使用了多态性,工厂方法模式保持了简单工厂模式的优点,而且克服了它的缺点。在工厂方法模式中,核心的工厂类不再负责所有产品的创建,而是将具体创建工作交给子类去做。这个核心类仅仅负责给出具体工厂必须实现的接口,而不接触哪一个产品类被实例化这种细节。这使得工厂方法模式可以允许系统在不修改工厂角 {MOD}的情况下引进新产品。在Factory Method模式中,工厂类与产品类往往具有平行的等级结构,它们之间一一对应。
二、 Factory Method模式角 {MOD}与结构:
抽象工厂(Creator)角 {MOD}:
是工厂方法模式的核心,与应用程序无关。任何在模式中创建的对象的工厂类必须实现这个接口。
具体工厂(Concrete Creator)角 {MOD}:
这是实现抽象工厂接口的具体工厂类,包含与应用程序密切相关的逻辑,并且受到应用程序调用以创建产品对象。在上图中有两个这样的角 {MOD}:BulbCreator与TubeCreator。
抽象产品(Product)角 {MOD}:
工厂方法模式所创建的对象的超类型,也就是产品对象的共同父类或共同拥有的接口。在上图中,这个角 {MOD}是Light。
具体产品(Concrete Product)角 {MOD}:
这个角 {MOD}实现了抽象产品角 {MOD}所定义的接口。某具体产品有专门的具体工厂创建,它们之间往往一一对应。
三、 程序举例:
using
System;
public
abstract
class
Light
{
public
abstract
void
TurnOn();
public
abstract
void
TurnOff();
}
public
class
BulbLight : Light
{
public
override
void
TurnOn()
{ Console.WriteLine(
"
Bulb Light is Turned on
"
); }
public
override
void
TurnOff()
{ Console.WriteLine(
"
Bulb Light is Turned off
"
); }
}
public
class
TubeLight : Light
{
public
override
void
TurnOn()
{ Console.WriteLine(
"
Tube Light is Turned on
"
); }
public
override
void
TurnOff()
{ Console.WriteLine(
"
Tube Light is Turned off
"
); }
}
public
abstract
class
Creator
{
public
abstract
Light factory();
}
public
class
BulbCreator : Creator
{
public
override
Light factory()
{
return
new
BulbLight(); }
}
public
class
TubeCreator : Creator
{
public
override
Light factory()
{
return
new
TubeLight(); }
}
public
class
Client
{
public
static
void
Main()
{
Creator c1
=
new
BulbCreator();
Creator c2
=
new
TubeCreator();
Light l1
=
c1.factory();
Light l2
=
c2.factory();
l1.TurnOn();
l1.TurnOff();
Console.WriteLine(
"
-----------------
"
);
l2.TurnOn();
l2.TurnOff();
}
}
工厂方法的活动序列图
活动过程包括:客户端创建BulbCreator对象,客户端持有此对象的类型是Creator,而实际类型是BulbCreator。然后客户端调用BulbCreator的factory方法,之后BulbCreator调用BulbLight的构造函数创造出产品BulbLight对象。
四、 工厂方法模式与简单工厂模式
工厂方法模式与简单工厂模式再结构上的不同不是很明显。工厂方法类的核心是一个抽象工厂类,而简单工厂模式把核心放在一个具体类上。工厂方法模式之所以有一个别名叫多态性工厂模式是因为具体工厂类都有共同的接口,或者有共同的抽象父类。当系统扩展需要添加新的产品对象时,仅仅需要添加一个具体对象以及一个具体工厂对象,原有工厂对象不需要进行任何修改,也不需要修改客户端,很好的符合了"开放-封闭"原则。而简单工厂模式在添加新产品对象后不得不修改工厂方法,扩展性不好。工厂方法模式退化后可以演变成简单工厂模式。
五、 Factory Method模式演化
使用接口或抽象类
抽象工厂角 {MOD}和抽象场频角 {MOD}都可以选择由接口或抽象类实现。
使用多个工厂方法
抽象工厂角 {MOD}可以规定出多于一个的工厂方法,从而使具体工厂角 {MOD}实现这些不同的工厂方法,这些方法可以提供不同的商业逻辑,以满足提供不同的产品对象的任务。
产品的循环使用
工厂方法总是调用产品类的构造函数以创建一个新的产品实例,然后将这个实例提供给客户端。而在实际情形中,工厂方法所做的事情可以相当复杂。一个常见的复杂逻辑就是循环使用产品对象。工厂对象将已经创建过的产品登记到一个聚集中,然后根据客户所请求的产品状态,向聚集查询。如果有满足要求的产品对象,就直接将产品返回客户端;如果聚集中没有这样的产品对象,那么就创建一个新的满足要求的产品对象,然后将这个对象登记到聚集中,再返还给客户端。"享元模式(Flyweight Pattern)"就是这样一个模式。
多态性的丧失和模式的退化
一个工厂方法模式的实现依赖于工厂角 {MOD}和产品角 {MOD}的多态性。在有些情况下,这个模式可以出现退化。工厂方法返回的类型应当是抽象类型,而不是具体类型。调用工厂方法的客户端应当依赖抽象产品编程,而不是具体产品。如果工厂仅仅返回一个具体产品对象,便违背了工厂方法的用意,发生退化,这时就不再是工厂模式了。工厂的等级结构:工厂对象应当有一个抽象的超类型。如果等级结构中只有一个具体工厂类的话,抽象工厂就可以省略,发生了退化。
[dvnews_page]
六、 Factory Method模式与其它模式的关系
与工厂方法模式有关的模式还包括:
模板方法模式、MVC模式、享元模式、备忘录模式
七、 另外一个例子
//
Factory Method pattern -- Real World example
using
System;
using
System.Collections;
//
"Product"
abstract
class
Page
{
}
//
"ConcreteProduct"
class
SkillsPage : Page
{
}
//
"ConcreteProduct"
class
EducationPage : Page
{
}
//
"ConcreteProduct"
class
ExperiencePage : Page
{
}
//
"ConcreteProduct"
class
IntroductionPage : Page
{
}
//
"ConcreteProduct"
class
ResultsPage : Page
{
}
//
"ConcreteProduct"
class
ConclusionPage : Page
{
}
//
"ConcreteProduct"
class
SummaryPage : Page
{
}
//
"ConcreteProduct"
class
BibliographyPage : Page
{
}
//
"Creator"
abstract
class
Document
{
//
Fields
protected
ArrayList pages
=
new
ArrayList();
//
Constructor
public
Document()
{
this
.CreatePages();
}
//
Properties
public
ArrayList Pages
{
get
{
return
pages; }
}
//
Factory Method
abstract
public
void
CreatePages();
}
//
"ConcreteCreator"
class
Resume : Document
{
//
Factory Method implementation
override
public
void
CreatePages()
{
pages.Add(
new
SkillsPage() );
pages.Add(
new
EducationPage() );
pages.Add(
new
ExperiencePage() );
}
}
//
"ConcreteCreator"
class
Report : Document
{
//
Factory Method implementation
override
public
void
CreatePages()
{
pages.Add(
new
IntroductionPage() );
pages.Add(
new
ResultsPage() );
pages.Add(
new
ConclusionPage() );
pages.Add(
new
SummaryPage() );
pages.Add(
new
BibliographyPage() );
}
}
/**/
///
///
FactoryMethodApp test
///
class
FactoryMethodApp
{
public
static
void
Main(
string
[] args )
{
Document[] docs
=
new
Document[
2
];
//
Note: constructors call Factory Method
docs[
0
]
=
new
Resume();
docs[
1
]
=
new
Report();
//
Display document pages
foreach
( Document document
in
docs )
{
Console.WriteLine(
"
"
+
document
+
"
-------
"
);
foreach
( Page page
in
document.Pages )
Console.WriteLine(
"
"
+
page );
}
}
}
参考文献:
阎宏,《Java与模式》,电子工业出版社
[美]James W. Cooper,《C#设计模式》,电子工业出版社
[美]Alan Shalloway James R. Trott,《Design Patterns Explained》,中国电力出版社
[美]Robert C. Martin,《敏捷软件开发-原则、模式与实践》,清华大学出版社
[美]Don Box, Chris Sells,《.NET本质论 第1卷:公共语言运行库》,中国电力出版社
放心去飞
来源:
CSDNBlog
阅读:
409
次
日期:
2004-12-17
录入:
admin
【
评论
】 【
推荐
】 【
打印
】 【 字体:
大
中
小
】 上一篇:
抽象工厂(Abstract Factory)模式
下一篇:
简单工厂(Simple Factory)模式
>> 相关文章
全部相关文章
设计模式-简单工厂模式(SimpleFactory...
(2004-12-23)
设计模式-工厂模式(手工作坊到工业化...
(2004-12-23)
设计模式笔记-抽象工厂模式
(2004-12-23)
设计模式原型模式(Prototype)- 面馆里...
(2004-12-23)
设计模式-建造模式(一碗牛肉面的制造...
(2004-12-23)
>>
本文评论
发表评论 Copyright © www.PutFly.com 2004-2005
放心去飞
Ta的文章
更多
>>
linux U盘插拔检测
0 个评论
工厂方法(Factory Method)模式
0 个评论
热门文章
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮