`
phinecos
  • 浏览: 342844 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

WebCast听课录(4)

 
阅读更多
课程名:C#面向对象设计模式纵横谈(3)Abstract Factory 抽象工厂模式(创建型模式)

创建型模式要解决的问题就是如何创建一个对象的问题。使用new的问题在于: 实现依赖,不能应对具体实例化类型的变化。这个问题的解决思路是: 封装变化点—— 哪里变化,封装哪里。

//创建一个Road对象
Roadroad=
roadFactory.CreateRoad();

如果以后Road类改变了,例如从泥土路变成了水泥路,那么代码就必须要进行大量修改。<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

关键就是如何封装变化点,将变化与系统其他稳定的部分隔离开,使其的更改不会对稳定部分产生影响

既然变化点在对象创建,因此就封装对象创建,原则是:面向接口编程——依赖接口,而非依赖实现。

最简单的解决方法:


classRoadFactory
{
publicstaticRoadCreateRoad()
{
returnnewRoad();
}

}

Roadroad
=RoadFactory.CreateRoad();


假设一个场景:需要构造道路房屋地道丛林”……等等对象.

classRoadFactory
{
publicstaticRoadCreateRoad()
{
returnnewRoad();
}

publicstaticBuildingCreateBuilding()
{
returnnewBuilding();
}

publicstaticTunnelCreateTunnel()
{
returnnewTunnel();
}

publicstaticJungleCreateJungle()
{
returnnewJungle();
}



简单工厂的问题:不能应对不同系列对象的变化。比如有不同风格的游戏场景——对应不同风格的道路、房屋、地道等。解决办法:使用面向对象的技术来封装变化点。

在软件系统中,经常面临着一系列相互依赖的对象的创建工作;同时,由于需求的变化,往往存在更多系列对象的创建工作。如何应对这种变化?如何绕过常规的对象创建方法(new),提供一种封装机制来避免客户程序和这种多系列具体对象创建工作的紧耦合?

意图:提供一个接口,让该接口负责创建一系列相关或者相互依赖的对象,无需指定它们具体的类。——《设计模式》GoF


2006101601.jpg

publicabstractclassRoad
{

}

publicabstractclassBuilding
{

}



publicabstractclassFacilitiesFactory
{
publicabstractRoadCreateRoad();

publicabstractBuildingCreateBuilding();

}



publicclassModernRoad:Road
{
publicModernRoad()
{
}

}

publicclassModernBuilding:Building
{
publicModernBuilding()
{
}

}



publicclassModernFacilitiesFactory:FacilitiesFactory
{
publicModernFacilitiesFactory()
{
}

publicoverrideRoadCreateRoad()
{
returnnewModernRoad();
}


publicoverrideBuildingCreateBuilding()
{
returnnewModernBuilding();
}

}


classGameManager
{
FacilitiesFactoryfacilitiesFactory;
Roadroad;
Buildingbuilding;
publicGameManager(FacilitiesFactoryfacilitiesFactory)
{
this.facilitiesFactory=facilitiesFactory;
}


publicvoidBuildGameFacilities()
{
this.road=this.facilitiesFactory.CreateRoad();
this.building=this.facilitiesFactory.CreateBuilding();

}


publicvoidPlay()
{
//.
}



}


classTest
{

publicstaticvoidMain(String[]args)
{
GameManagerg
=newGameManager(newModernFacilitiesFactory());
g.BuildGameFacilities();
g.Play();
}


}


Abstract Factory模式的几个要点

1,如果没有应对多系列对象构建的需求变化,则没有必要使用Abstract Factory模式,这时候使用简单的静态工厂完全可以。

2系列对象指的是这些对象之间有相互依赖、或作用的关系,例如游戏开发场景中的道路房屋的依赖,道路地道的依赖。

3 Abstract Factory 模式主要在于应对新系列的需求变动。其缺点在于难以应对新对象的需求变动。

4 Abstract Factory 模式经常和Factory Method模式共同组合来应对对象创建的需求变化。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics