【设计模式】6、适配器模式

抽象类

 1 package com.shejimoshi.structural.Adapter;
 2
 3
 4 /**
 5  * 功能:适配器模式
 6  *         将一个类的接口转换成客户希望的另外一个接口。adapter模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作
 7  * 适用性:你想使用一个已经存在的类,而它的接口不符合你的需求
 8  *          你想创建一个可以复用的类,该类可以与其他不相关的类或不可预见的类协同工作
 9  *         你想使用一些已经存在的子类,但是不可能对每一个都进行子类化以匹配它们的接口。对象适配器可以适配它的类接口
10  * 时间:2016年2月17日下午5:43:46
11  * 作者:cutter_point
12  */
13 public abstract class Player
14 {
15     protected String name;    //运动员名字
16
17     public Player(String name)
18     {
19         this.name = name;
20     }
21
22     //进攻
23     public abstract void attack();
24     //防守
25     public abstract void defense();
26 }

前锋

 1 package com.shejimoshi.structural.Adapter;
 2
 3
 4 /**
 5  * 功能:这个是我们的前锋类,这个我们不需要适配
 6  * 时间:2016年2月17日下午5:50:01
 7  * 作者:cutter_point
 8  */
 9 public class Forwards extends Player
10 {
11
12     public Forwards(String name)
13     {
14         super(name);
15     }
16
17     @Override
18     public void attack()
19     {
20         System.out.println("前锋" + name + "进攻");
21     }
22
23     @Override
24     public void defense()
25     {
26         System.out.println("前锋" + name + "防守");
27     }
28
29 }

中锋

 1 package com.shejimoshi.structural.Adapter;
 2
 3
 4 /**
 5  * 功能:我们的中锋类
 6  * 时间:2016年2月17日下午5:54:50
 7  * 作者:cutter_point
 8  */
 9 public class Center extends Player
10 {
11
12     public Center(String name)
13     {
14         super(name);
15     }
16
17     @Override
18     public void attack()
19     {
20         System.out.println("中锋" + name + "进攻");
21     }
22
23     @Override
24     public void defense()
25     {
26         System.out.println("中锋" + name + "防守");
27     }
28
29 }

后卫

 1 package com.shejimoshi.structural.Adapter;
 2
 3
 4 /**
 5  * 功能:后卫
 6  * 时间:2016年2月17日下午5:56:12
 7  * 作者:cutter_point
 8  */
 9 public class Guards extends Player
10 {
11
12     public Guards(String name)
13     {
14         super(name);
15     }
16
17     @Override
18     public void attack()
19     {
20         System.out.println("后卫" + name + "进攻");
21     }
22
23     @Override
24     public void defense()
25     {
26         System.out.println("后卫" + name + "防守");
27     }
28
29 }

翻译者,我们的适配器类

 1 package com.shejimoshi.structural.Adapter;
 2
 3
 4 /**
 5  * 功能:翻译者,为了适配外籍中锋
 6  * 时间:2016年2月17日下午6:00:36
 7  * 作者:cutter_point
 8  */
 9 public class Translator extends Player
10 {
11
12     private ForeignCenter fc = new ForeignCenter();
13
14     public Translator(String name)
15     {
16         super(name);
17         fc.setName(name);
18     }
19
20     @Override
21     public void attack()
22     {
23         fc.ForeignAttack();
24     }
25
26     @Override
27     public void defense()
28     {
29         fc.foreignDefense();
30     }
31
32 }

被适配类,外籍中锋

 1 package com.shejimoshi.structural.Adapter;
 2
 3
 4 /**
 5  * 功能:外籍中锋
 6  * 时间:2016年2月17日下午5:57:09
 7  * 作者:cutter_point
 8  */
 9 public class ForeignCenter
10 {
11     private String name;
12
13     //默认构造函数
14     public ForeignCenter()
15     {}
16
17     public ForeignCenter(String name)
18     {
19         this.name = name;
20     }
21
22     //进攻
23     public void ForeignAttack()
24     {
25         System.out.println("foreignCenter" + name + "attack !!");
26     }
27
28     //防守
29     public void foreignDefense()
30     {
31         System.out.println("foreignCenter" + name + "defense !!");
32     }
33
34     public String getName()
35     {
36         return name;
37     }
38
39     public void setName(String name)
40     {
41         this.name = name;
42     }
43
44 }

测试代码:

 1 package com.shejimoshi.structural.Adapter;
 2
 3
 4 /**
 5  * 功能:适配器模式的使用
 6  * 时间:2016年2月17日下午6:03:03
 7  * 作者:cutter_point
 8  */
 9 public class Test
10 {
11     public static void main(String[] args)
12     {
13         Player z = new Forwards("周星驰");
14         z.attack();
15
16         Player y = new Center("姚明");
17         y.attack();
18
19         //使用翻译者作为适配器使用外籍中锋类
20         Player cp = new Translator("cutter_point");
21
22         cp.attack();
23         cp.defense();
24
25     }
26 }

显示结果:

1 前锋周星驰进攻
2 中锋姚明进攻
3 foreignCentercutter_pointattack !!
4 foreignCentercutter_pointdefense !!
时间: 2024-08-14 15:40:50

【设计模式】6、适配器模式的相关文章

设计模式之适配器模式

适配器模式(Adapter Pattern)有时候也称包装样式或者包装.将一个类的接口转接成用户所期待的.一个适配使得因接口不兼容而不能在一起工作的类工作在一起,做法是将类别自己的接口包裹在一个已存在的类中. Adapter Pattern有两种: 类的Adapter Pattern(继承) 对象的Adapter Pattern(委托) 下面我们用第一种来实现适配器模式: 我们首先来看看类图: 具体实现如下: Banner类: public class Banner { private Stri

设计模式之适配器模式(Adapter Pattern)

适配器模式(Adapter):将一个类的接口转换成客户希望的另外一个接口.Adapter模式使得原本由于接口不兼容而不能一起工作的那些类可以在一起工作. 1. 解决的问题 即Adapter模式使得原本由于接口不兼容而不能一起工作的那些类可以在一起工作. 2. 模式中的角色 2.1 目标接口(Target):客户所期待的接口.目标可以是具体的或抽象的类,也可以是接口. 2.2 需要适配的类(Adaptee):需要适配的类或适配者类. 2.3 适配器(Adapter):通过包装一个需要适配的对象,把

大话设计模式_适配器模式(Java代码)

适配器模式:将一个类的接口转换成客户希望的另外一个接口.Adapter模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作. 简单描述: 大话设计模式中的截图: 代码例子: AbstractPlayer类: 1 package com.longsheng.adapter; 2 3 public abstract class AbstractPlayer { 4 5 public abstract void attack(); 6 7 public abstract void defenc

螃蟹学PHP设计模式之适配器模式

之前对java的设计模式略有了解,但是螃蟹目前是靠PHP吃饭,所以对于进阶学习php设计模式还是很有必要.螃蟹虽然做开发两年了,但是在老鸟眼中还是菜鸟,为了自己写的代码更容易维护和进行团队协作,所以我要搞定设计模式.希望螃蟹今年能创业成功或找个好工作. 1.适配器模式 螃蟹的理解是你买了港行的iphone手机,发现自家的插座和手机自带的插头不配,怎么办呢,就需要一个转换器(适配器).可能原来系统的类不是你设计的,但是现在你要使用原来的类,发现有问题,但原来的类又不能动,或者不需要动,这样你写一个

Java设计模式之适配器模式(Adapter Pattern)

Adapter Pattern的作用是在不改变功能的前提下转换接口.Adapter分为两类,一类是Object Adapter, 另一类是Class Adapter.由于Class Adapter的实现需要用到多继承,而Java不支持多继承,所以这里只关注Object Adapter. 在JDK1.5之前是没有 java.util.Iterator 接口的,java.util.Enumeration 接口起着 Iterator 的作用.那么如果我们需要维护一些年代比较久远的代码,可能就会面临着没

Head First 设计模式之适配器模式与外观模式

Head First设计模式之适配器模式与外观模式 前言: 之前讲过装饰者模式,将对象包装起来并赋予新的职责,这一章我们也会将对象进行包装,只不过是让它们看起来不像自己而像是别的东西.这样就可以在设计中将类的接口转化为想要的接口,以实现同的接口,此外还将讲述另一个模式,将对象包装起来以简化接口. 1.   适配器简介 1.1 面向对象的适配器 真实世界的适配器比如位于美式插头和欧式插座之间的交流电适配器.面向对象的适配器是什么呢? 面向对象的适配器是将一个接口转化成另一个接口,以符合客户的期望.

每天一个设计模式-3 适配器模式(Adapteer)

每天一个设计模式-3 适配器模式(Adapteer) 1.现实中的情况 旧式电脑的硬盘是串口的,直接与硬盘连接,新硬盘是并口的,显然新硬盘不能直接连在电脑上,于是就有了转接线.好了,今天的学习主题出来了“适配器”. 2.联系编程 有一个电源类,一个旧的硬盘类,还有一个新硬盘类:电源类能直接适配旧硬盘类,但不能和新硬盘适配. 这时,可以添加一个适配器类,这里采用对象引用的方式实现适配器. 3.类图 模式简图: 测试时使用的类图: 4.代码 NewDiskApi: public interface

Java编程思想笔记02:组合与继承、final、策略设计模式与适配器模式、内部类、序列化控制(注意事项)

1.组合和继承之间的选择 组合和继承都允许在新的类中放置子对象,组合是显式的这样做,而继承则是隐式的做. 组合技术通常用于想在新类中使用现有类的功能而非它的接口这种情形.即在新类中嵌入某个对象,让其实现所需要的功能,但新类的用户看到的只是为新类所定义的接口,而非所嵌入对象的接口.为取得此效果,需要在新类中嵌入一个现有类的private对象.但有时,允许类的用户直接访问新类中的组合成分是极具意义的,即将成员对象声明为public.如果成员对象自身都隐藏了具体实现,那么这种做法是安全的.当用户能够了

JAVA学习笔记--策略设计模式与适配器模式

一.策略设计模式 创建一个能够根据所传递对象的不同而具有不同行为的方法被称为策略设计模式:这类方法包含所要执行的算法中固定不变的部分,而"策略"包含变化的部分.策略就是传递进去的参数对象,它包含要执行的代码. 这种设计模式将算法分别独立封装起来,然后将其当做参数传递给方法从而让方法产生不同的行为,不同的算法可以进行替换(就像给方法不同的实参).我们可以知道,在策略设计模式中有三个部分:策略.策略引用.接收策略引用的方法(这是笔者自己根据理解给出的名词,并没有查询有没有这些术语).下面通

07.设计模式_适配器模式

转载自  http://www.cnblogs.com/zhili/p/AdapterPattern.html 一.引言 在实际的开发过程中,由于应用环境的变化(例如使用语言的变化),我们需要的实现在新的环境中没有现存对象可以满足,但是其他环境却存在这样现存的对象.那么如果将"将现存的对象"在新的环境中进行调用呢?解决这个问题的办法就是我们本文要介绍的适配器模式--使得新环境中不需要去重复实现已经存在了的实现而很好地把现有对象(指原来环境中的现有对象)加入到新环境来使用. 二.适配器模