程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> java設計形式之適配器形式

java設計形式之適配器形式

編輯:關於JAVA

java設計形式之適配器形式。本站提示廣大學習愛好者:(java設計形式之適配器形式)文章只能為提供參考,不一定能成為您想要的結果。以下是java設計形式之適配器形式正文


感激《Android源碼設計形式解析與實戰》 何紅輝 關愛平易近 著 

適配器形式在我們的開辟中應用率極高,從代碼中到處可見的Adapter便可以斷定出來,從最早的ListView、GridView、到如今最新的RecyclerView都須要應用Adapter,而且在開辟中我們碰到的優化成績、失足幾率較年夜的處所也根本都出自Adapter。 

適配器是將兩個不兼容的火龍融會在一路,將分歧的器械經由過程一種轉換使得它們可以或許協作起來,例如,常常碰著要在兩個沒有關系的類型之間停止交互,第一個處理計劃是修正各自類的接口,然則假如沒有源代碼或許我們不肯意為了一個運用而修正各自的接口,這類情形我們常常會應用一個Adapter,這個Adapter會將這兩個接口停止兼容,在不修正原有代碼的情形下知足需求。 

假定已有一個軟件體系,你願望它能和一個新的廠商類庫搭配應用,然則這個新廠商所設計出來的接口,不消於舊廠商的接口: 

你不想轉變現有的代碼,處理這個成績(也不克不及轉變廠商的代碼),應當怎樣做?你可以寫一個類(適配器),將新廠商接口轉接成你所希冀的接口,這個適配器任務起來就好像一個中央人,它將客戶所收回的要求轉換成廠商類能懂得的要求。 

適配器形式可分為兩種: 

對象適配器:充斥著優越的OO設計准繩,應用對象組合,可以運用在適配者是接口和它一切的子類,不克不及夠重寫適配器的辦法,由於沒有繼續關系,然則也可以或許“從新完成”適配者中辦法,客戶端和適配者完整不相關,只要適配器具有適配者的援用。 

類適配器:應用繼續的方法到達適配的任務,只能是適配者是接口,不克不及應用它子類的接口,當類適配器樹立時,它就靜態地與適配者聯系關系,適配者作為適配器的基類,所以適配器可以或許重寫適配器中的辦法,客戶端代碼對適配者中聲明的代碼是可見的客戶端代碼對適配者中聲明的代碼是可見的。

界說: 

適配器形式把一個類的接口變換成客戶端所等待的另外一種接口,從而使本來因接口不婚配而沒法在一路任務的兩個類可以或許在一路任務。 

應用場景: 

1.體系須要應用現有的類,而此類的接口不相符體系的須要,即接口不兼容。 

2.想要樹立一個可以反復應用的類,用於與一些彼此之間沒有太年夜聯系關系的一些類,包含一些能夠在未來引進的類一路任務。 

3.須要一個同一的輸入接口,而輸出真個類型弗成預知。 

UML類圖:

起首看下類適配器:

 

類適配器是經由過程完成Target接口和繼續Adaptee類來完成接口轉換,例如,目的接口須要的是operation2,然則Adaptee對象只要一個operation3,是以就湧現了不兼容的情形。此時經由過程Adapter完成一個operation2函數將Adaptee的operation3轉換成Target須要的operation2,以此完成兼容。

Target : 目的腳色,也就是所等待獲得的接口。留意:因為這裡評論辯論的是類適配器形式,是以目的弗成所以類。 

Adaptee : 如今須要適配的接口。 

Adapter: 適配器腳色,也是本形式的焦點,適配器把源接口轉換成目的接口。這一腳色弗成所以接口,而必需是詳細類。 

類適配器形式示例:

以年夜陸電壓為220v,手電機壓為5v為例

/**
 * 電壓類 Target目的
 * @author Administrator
 *
 */
public interface Voltage {
 public int getVoltage();
}public class ChinaVoltage implements Voltage{

 @Override
 public int getVoltage() {
 // 年夜陸電壓為220
 return 220;
 }

}<pre name="code" class="java">/**
 * 手機類, Adaptee 被適配者類
 * @author Administrator
 *
 */
public class PhoneVoltage {
 /**
 * 手電機壓為5v
 * @return
 */
 public int getPhoneVoltage(){
 return 5;
 }
}
 

<pre name="code" class="java">/**
 * 充電器 Adapter 適配器類
 * @author Administrator
 *
 */
public class Charger extends PhoneVoltage implements Voltage {

 @Override
 public int getVoltage() {
 return getPhoneVoltage();
 }

}
 
public class Client {
 public static void main(String[] args) {
 ChinaVoltage vol = new ChinaVoltage();
 System.out.println("年夜陸電壓為 : " + vol.getVoltage());
 //為手機接入充電器時的電壓
 Chargerr character = new Chargerr();
 System.out.println("經由過程充電器轉換後的電壓 : " + character.getVoltage());
 }
}

運轉成果:
年夜陸電壓為 : 220
經由過程充電器轉換後的電壓 : 5

再看一下對象適配器類圖:

 

上面以對象適配器修正Chargerr類

<pre name="code" class="java">/**
 * 充電器 Adapter 適配器類
 * @author Administrator
 *
 */
public class Chargerr implements Voltage{
 private PhoneVoltage phoneV;
 
 public Chargerr(PhoneVoltage phoneV) {
 this.phoneV = phoneV;
 }
 
 @Override
 public int getVoltage() {
 return phoneV.getPhoneVoltage();
 }
}

對象適配器完成方法直接將要被適配的對象傳遞到Adapter中,應用組合的情勢完成接口兼容的後果,這比類適配器方法更加靈巧,它的另外一個利益是被適配對象中的辦法不會裸露出來,而類適配器因為繼續了被適配對象,是以,被適配對象類的函數在Adapter類中也都含有,這使得Adapter類湧現一些奇異的接口,用戶應用本錢較高。是以,對象適配器形式加倍靈巧、適用。

public class Client {
 public static void main(String[] args) {
// ChinaVoltage vol = new ChinaVoltage();
// System.out.println("年夜陸電壓為 : " + vol.getVoltage());
// //為手機接入充電器時的電壓
// Chargerr character = new Chargerr();
// System.out.println("經由過程充電器轉換後的電壓 : " + character.getVoltage());
 //被適配者
 PhoneVoltage phoneV = new PhoneVoltage();
 Chargerr chargerr = new Chargerr(phoneV);
 System.out.println("經由過程充電器轉換後的電壓:" + chargerr.getVoltage());
 
 }
 //運轉成果:
 // 經由過程充電器轉換後的電壓:5
}

總結:
Adapter形式的經典完成在於將本來不兼容的接口融會在一路,使之可以或許很好地停止協作。然則,在現實開辟中,Adapter形式也有一些靈巧的完成。例如ListView中的隔離變更,使得全部UI架構變得更靈巧,可以或許擁抱變更。Adapter形式在開辟呂應用異常普遍。 

長處: 

更好的復用性:體系須要應用現有的類,而此類的接口不相符體系的須要。那末經由過程適配器形式便可以讓這些功效獲得更好的復用。 

更好的擴大性:在完成適配器功效的時刻,可以挪用本身開辟的功效,從而天然地擴大體系的功效。 

缺陷:

過量的應用適配器,會讓體系異常零亂,不容易速體掌握。例如,明明看到挪用的昌A接口,其實外部被適配成了B接口的完成,一個體系假如太多湧現這類情形,無異於一場災害。是以,假如不是有需要,可以不應用適配器,而是直接對體系停止重構。

以上就是本文的全體內容,願望對年夜家的進修有所贊助,也願望年夜家多多支撐。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved