把一个类的接口变换成客户端所期待的另一种接口,从而使原本因接口不匹配而无法在一起工作的两个类能够在一起工作。
适配器模式有类的适配器模式、对象的适配器模式、默认适配器模式三种不同的形式。
public class Person { public void speakJapanese(){ System.out.println("I can speak Japanese!"); } public void speakEnglish(){ System.out.println("I can speak English!"); } } public interface Job { public abstract void speakJapanese(); public abstract void speakEnglish(); public abstract void speakFrench(); } public class Adapter extends Person implements Job{ public void speakFrench() { } }好了,代码看完然后要做一些说明了,之前遗留的一个问题,为什么称其为类适配模式呢?很显然的,Adapter类继承了Person类,而在Java这种单继承的语言中也就意味着,他不可能再去继承其他的类了,这样也就是这个适配器只为Person这一个类服务。所以称其为类适配模式。
public interface Job { public abstract void speakJapanese(); public abstract void speakEnglish(); public abstract void speakFrench(); } public class Adapter implements Job { Person person; public Adapter(Person person) { this.person = person; } public void speakEnglish() { person.speakEnglish(); } public void speakJapanese() { person.speakJapanese(); } //new add public void speakFrench() { } }对象的适配器模式,把“源”作为一个构造参数传入适配器,然后执行接口所要求的方法。这种适配模式可以为多个源进行适配。弥补了类适配模式的不足。
这种模式的核心归结如下:当你想实现一个接口但又不想实现所有接口方法,只想去实现一部分方法时,就用中默认的适配器模式,他的方法是在接口和具体实现类中添加一个抽象类,而用抽象类去空实现目标接口的所有方法。而具体的实现类只需要覆盖其需要完成的方法即可。代码如下:
public interface Job { public abstract void speakJapanese(); public abstract void speakEnglish(); public abstract void speakFrench(); public abstract void speakChinese(); } public abstract class JobDefault implements Job{ public void speakChinese() { } public void speakEnglish() { } public void speakFrench() { } public void speakJapanese() { } } public class JobImpl extends JobDefault{ public void speakChinese(){ System.out.println("I can speak Chinese!"); } }
原文:http://blog.csdn.net/chenyiming_1990/article/details/22532061