適配器模式(Adapter)

7種結構型模式:適配器模式、裝飾模式、代理模式、外觀模式、橋接模式、組合模式、享元模式。其中對象的適配器模式是各類模式的起源    java

適配器模式將某個類的接口轉換成客戶端指望的另外一個接口表示,目的是消除因爲接口不匹配所形成的類的兼容性問題。主要分爲三類:類的適配器模式、對象的適配器模式、接口的適配器模式。首先,咱們來看看類的適配器模式,先看類圖:app

\ide

核心思想就是:有一個Source類,擁有一個方法,待適配,目標接口是Targetable,經過Adapter類,將Source的功能擴展到Targetable裏,看代碼:測試

原始類與適配接口this

public class Source {
	public void method1(){
		System.out.println("原始方法");
	}
}
public interface Targetable {
	//原始方法
	public void method1();
	//新增方法
	public void method2();
}

新增的類,繼承於原始類,實現接口Targetable
spa

public class Adapter extends Source implements Targetable{
	@Override
	public void method2() {
		System.out.println("新類的方法");
		
	}
}

測試類:代理

public class Test {
	public static void main(String[] args) {
		//實例化接口對象,Soutce類的方法已經擴展到接口裏面去了
		Targetable target=new Adapter();
		//調用接口方法,來自原始類的方法
		target.method1();
		//調用接口方法,來自新增類的方法
		target.method2();
	}
}

測試結果:code

原始方法orm

新類的方法對象

重點是經過目標接口和它的實現類(Adapter),把原始類的方法適配(擴展)到目標接口裏面去

這樣Targetable接口的實現類就具備了Source類的功能。


對象的適配器模式

基本思路和類的適配器模式相同,只是將Adapter類做修改,此次不繼承Source類,

而是持有Source類的實例,以達到解決兼容性的問題。看圖:


只須要修改Adapter類的源碼便可:

public class Wrapper  implements Targetable{
	
	private Source source;
	
	public Wrapper(Source source){
		super();
		this.source=source;
	}
	
	@Override
	public void method2() {
		System.out.println("新類的方法");
		
	}

	@Override
	public void method1() {
		// TODO Auto-generated method stub
		source.method1();
	}
}

測試類:

public class Test {
	public static void main(String[] args) {
		Source source=new Source();
		//實例化接口對象,實現類是Adapter
		Targetable target=new Wrapper(source);
		//調用接口的方法
		target.method1();
		target.method2();	
	}
}

輸出與第一種同樣,只是適配的方法不一樣而已。

接口的適配器模式

接口的適配器是這樣的:有時咱們寫的一個接口中有多個抽象方法,當咱們寫該接口的實現類時,必須實現該接口的全部方法,這明顯有時比較浪費,由於並非全部的方法都是咱們須要的,有時只須要某一些,此處爲了解決這個問題,咱們引入了接口的適配器模式,藉助於一個抽象類,該抽象類實現了該接口,實現了全部的方法,而咱們不和原始的接口打交道,只和該抽象類取得聯繫,因此咱們寫一個類,繼承該抽象類,重寫咱們須要的方法就行。看一下類圖:

這個很好理解,在實際開發中,咱們也常會遇到這種接口中定義了太多的方法,以至於有時咱們在一些實現類中並非都須要。看代碼:

public interface Sourceable {
	public void method1();

	public void method2();
}

抽象類Wrapper2:

public class Wrapper2 implements Sourceable{

	@Override
	public void method1() {
	
	}

	@Override
	public void method2() {

	}

}

繼承Wrapper2的兩個子類

public class SourceSub1 extends Wrapper2 {
	public void method1() {
		System.out.println("SourceSub1實現了接口Sourceable的第一個方法method1");
	}
}
public class SourceSub2 extends Wrapper2 {
	public void method2() {
		System.out.println("SourceSub2實現了接口Sourceable的第二個方法method2");
	}
}

測試類

public class Test {

	public static void main(String[] args) {
		Sourceable source1=new SourceSub1();
		Sourceable source2=new SourceSub2();
		
		source1.method1();
		source1.method2();
		source2.method1();
		source2.method2();
	}
}

測試結果:

SourceSub1實現了接口Sourceable的第一個方法method1

SourceSub2實現了接口Sourceable的第二個方法method2

達到了咱們的效果!

 講了這麼多,總結一下三種適配器模式的應用場景:

類的適配器模式:當但願將一個類轉換成知足另外一個新接口的類時,可使用類的適配器模式,建立一個新類,繼承原有的類,實現新的接口便可。

對象的適配器模式:當但願將一個對象轉換成知足另外一個新接口的對象時,能夠建立一個Wrapper類,持有原類的一個實例,在Wrapper類的方法中,調用實例的方法就行。

接口的適配器模式:當不但願實現一個接口中全部的方法時,能夠建立一個抽象類Wrapper,實現全部方法,咱們寫別的類的時候,繼承抽象類便可。

相關文章
相關標籤/搜索