完整word版设计模式实验Word格式文档下载.docx
《完整word版设计模式实验Word格式文档下载.docx》由会员分享,可在线阅读,更多相关《完整word版设计模式实验Word格式文档下载.docx(64页珍藏版)》请在冰豆网上搜索。

1
f=newAcerFactory();
}
interfaceFactory{
ComputergetComputerType();
classDellFactoryimplementsFactory{
@Override
publicComputergetComputerType(){
returnnewDell();
classAcerFactoryimplementsFactory{
returnnewAcer();
classLenovoFactoryimplementsFactory{
returnnewLenovo();
/**
*电脑品牌
*/
interfaceComputer{
publicvoidComputerType();
classDellimplementsComputer{
publicvoidComputerType(){
//TODOAuto‐generatedmethodstub
2
System.out.println("
DellComputer"
);
classAcerimplementsComputer{
AcerComputer"
classLenovoimplementsComputer{
LenovoComputer"
【运行截图】
【实验小结】
通过本次实验,学会了使用工厂方法模式。
工厂方法模式的适用性如下:
当一个类不知道它所必须创建的对象的类时。
当一个类希望由它的子类来指定它所创建的对象时。
当类将创建对象的职责委托给多个帮助子类中的某一个,并且希望将哪
一个帮助子类是代理这一信息局部化时。
3
实验二抽象工厂模式的应用
1)掌握抽象工厂模式(AbstractFactory)的特点
2)分析具体问题,使用抽象工厂模式进行设计。
麦当劳(McDonalds)和肯德基(KFC)快餐店都经营汉堡(Hamburg)和
可乐(Cola),用JAVA控制台应用程序实现这两个快餐店经营产品的抽象工厂
模式。
【模式UML图】
【模式代码】
publicclassAbstractFactoryTest{
Hamburgh;
Colac;
AbstractFactoryaf=newMDNFactory();
4
h=af.createHamburg();
c=af.createCola();
h.getHumburg();
c.getCola();
af=newKDJFactory();
interfaceAbstractFactory{
HamburgcreateHamburg();
ColacreateCola();
classMDNFactoryimplementsAbstractFactory{
publicHamburgcreateHamburg(){
returnnewMDNHamburg();
publicColacreateCola(){
returnnewMDNCola();
classKDJFactoryimplementsAbstractFactory{
returnnewKDJHamburg();
returnnewKDJCola();
*kDJ&
MDN
interfaceHamburg{
5
voidgetHumburg();
classMDNHamburgimplementsHamburg{
publicvoidgetHumburg(){
MDNHamburg"
classKDJHamburgimplementsHamburg{
KDJHamburg"
interfaceCola{
voidgetCola();
classMDNColaimplementsCola{
publicvoidgetCola(){
MDNCola"
classKDJColaimplementsCola{
KDJCola"
【运行截图】
6
抽象工厂模式主要适用于以下情况:
一系列要独立于它的产品的创建、组合和表示时。
、
一个系统要由多个产品系列中的一个来配置时。
当要强调一系列相关的产品对象的设计以便进行联合使用时。
当要提供一个产品类库,而只要显示它们的接口而不是实现时。
7
实验三适配器模式的应用
1)掌握适配器模式(Adapter)的特点
2)分析具体问题,使用适配器模式进行设计。
一个软件团队开发绘图系统,设计了圆对象(Circle)、矩形对象(Rectangle),
线对象(Line)都支持Draw()函数,即可以通过Draw()函数绘制图形。
为了加快项
目进度,将角度对象(Angle)绘制功能交给了合作团队实现。
但合作团队将角度
对象绘制函数定为了DrawAngle()。
绘图系统提供给用户后,用户不满意,希望
能统一的调用,不用记太多命令。
应用适配器模式,用JAVA控制台应用程序完
善该设计。
【模式代码】
publicclassAdapterTest{
Painta=newAngleAdapter();
a.draw();
8
interfacePaint{
voiddraw();
classCircleimplementsPaint{
publicvoiddraw(){
圆圆"
classRectangleimplementsPaint{
方方"
classLineimplementsPaint{
线线"
classAngle{
publicvoidDrawAngle(){
角度"
classAngleAdapterimplementsPaint{
privateAnglea=newAngle();
a.DrawAngle();
}
9
适配器模式主要适用于以下情况:
当想要使用一个已经存在的类,但是该类的接口不符合现有的需求时。
当需要创建一个可以被复用的类,该类能够与其他无关的类甚至无法预见的
类协同工作时。
当需要使用一个已经存在的子类,但是不可能对所有的都进行子类化以匹配
他们的接口时,对象适配器可以对其父类接口进行适配。
10
实验四桥接模式的应用
1)掌握桥接模式(Bridge)的特点
2)分析具体问题,使用桥接模式进行设计。
一个咖啡店可以提供大杯(JorumCoffee)、中杯(MediumCoffee)、小杯
(SmallCoffee)的咖啡(Coffee),为了满足不同用户的口味,在咖啡中可以添加牛奶
(Milk),或者糖(Sugar),或者柠檬(Lemon),提供给用户不同口味的组合,如大
杯咖啡加牛奶,中杯咖啡加糖,小杯咖啡加柠檬,小杯咖啡加糖等。
应用桥接模
式,用JAVA控制台应用程序实现该设计。
【模式类图】
packageConstructor;
publicclassBridgeTest{
Bridgeb;
b=newSugar();
11
b.setCoffee(newJorumCoffee());
b.getCoffee();
b=newMilk();
b.setCoffee(newSmallCoffee());
interfaceCoffee{
voidgetCoffee();
classJorumCoffeeimplementsCoffee{
publicvoidgetCoffee(){
System.out.print("
大杯咖啡"
classMediumCoffeeimplementsCoffee{
中杯咖啡"
classSmallCoffeeimplementsCoffee{
小杯咖啡"
*配料
abstractclassBridge{
protectedCoffeec;
voidsetCoffee(Coffeeco){
c=co;
publicvoidgetCoffee(){
c.getCoffee();
12
classSugarextendsBridge{
加糖"
classMilkextendsBridge{
加牛奶"
classLemonextendsBridge{
加柠檬"
桥接模式的适用情况有:
当不希望在抽象和它的实现之间有一个固定的绑定关系时。
当类的抽象以及它的实现都应该可以通过生成子类的方法加以扩充时。
当对一个抽象类的实现部分的修改应对客户不产生影响时。
13
实验五装饰模式的应用
1)掌握装饰模式(Decorator)的特点
2)分析具体问题,使用装饰模式进行设计。
“喜羊羊逃命”游戏:
喜羊羊被灰太狼追,喜羊羊最多5条命,灰太狼每咬到
喜羊羊一次,喜羊羊就要少一条命。
在逃的过程中喜羊羊可以吃到三种苹果,吃
“红苹果”可以给喜羊羊加上保护罩,吃“绿苹果”可以加快喜羊羊奔跑速度,吃“黄
苹果”可以使喜羊羊趟着水跑。
应用装饰模式,用JAVA控制台应用程序实现该
设计。
绘制该模式的UML图。
提示:
这个例子如果用类的继承来实现的话那可就麻烦了,你需要为喜羊羊
派生3*2*1=6个子类(有保护罩的喜羊羊,奔跑速度加快的喜羊羊,会趟水的喜
羊羊,既有保护罩又会趟水的喜羊羊,奔跑速度快且会趟水的喜羊羊,有保护罩
且奔跑速度快的喜羊羊,有保护罩、奔跑速度快且会趟水的喜羊羊),如果使用
装饰模式的那就不用派生诸多子类了,当喜羊羊每吃到一个苹果,我们就用装饰
模式给喜羊羊加一个动态增加一个新功能即可。
14
publicclassDecoratorTest01{
ConcreteXiYYcxyy=newConcreteXiYY();
ProtectXiYangyangpx=newProtectXiYangyang();
FastXiYangyangfx=newFastXiYangyang();
SwimingXiYangyangsx=newSwimingXiYangyang();
px.setXiYangyang(cxyy);
px.Operation();
fx.setXiYangyang(px);
fx.Operation();
sx.setXiYangyang(fx);
sx.Operation();
interfaceXiYangyang{
publicvoidOperation();
classConcreteXiYYimplementsXiYangyang{
publicvoidOperation(){
喜羊羊"
abstractclassDecoratorimplementsXiYangyang{
protectedXiYangyangxyy;
publicvoidsetXiYangyang(XiYangyangxyy){
this.xyy=xyy;
xyy.Operation();
15
classProtectXiYangyangextendsDecorator{
有保护罩的"
super.Operation();
classFastXiYangyangextendsDecorator{
加速的"
classSwimingXiYangyangextendsDecorato