六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

基于Java的建造設計模式

[摘要]一、引子   前幾天陪朋友去裝機店攢了一臺電腦,看著裝機工在那里熟練的裝配著機器,不禁想起來了培訓時講到的建造模式。作為裝機工,他們不用管你用的CPU是Intel還是AMD,也不管你的顯卡是2000千大元還是白送的,都能攣宄淖芭湓諞黃稹惶≒C就誕生了!當然對于客戶來說,你也不知道太多關于...
一、引子

  前幾天陪朋友去裝機店攢了一臺電腦,看著裝機工在那里熟練的裝配著機器,不禁想起來了培訓時講到的建造模式。作為裝機工,他們不用管你用的CPU是Intel還是AMD,也不管你的顯卡是2000千大元還是白送的,都能攣宄淖芭湓諞黃稹惶≒C就誕生了!當然對于客戶來說,你也不知道太多關于PC組裝的細節。這和建造模式是多么的相像啊!

  今天就來探討一下建造模式

  二、定義與結構

  GOF給建造模式的定義為:將一個復雜對象的構建與它的表示分離,使得同樣的構建過程可以創建不同的表示。可以將建造模式的精髓概括為:將構造復雜對象的過程和對象的部件解耦。這是對降低耦合、提高可復用性精神的一種貫徹。其實這種精神貫徹在GOF幾乎所有的設計模式中。

  是不是和上面提到的裝機流程相像?

  這個很多人認為同抽象工廠模式相似的建造模式用在什么樣的設計環境下呢(對于兩者的比較稍候討論)?我認為可以總結為以下環境:當要生成的產品有復雜的內部結構,其中的內部結構由多個對象組成;系統將來可能要改變產品對象的內部結構的構成或者實現方式,比如說產品的一些屬性現在是從數據庫中得到的,而將來可能從XML中解析得到;而且不能將產品的內部構造完全暴露給客戶程序,一是為了可用性,二是為了安全等因素。滿足上面的設計環境就可以考慮使用建造模式來搭建框架了。 來看看建造模式的組成吧。

  抽象建造者角色:這個角色用來規范產品對象的各個組成成分的建造。一般而言,此角色獨立于應用程序的商業邏輯。

  具體建造者角色:擔任這個角色的是于應用程序緊密相關的類,它們在指導者的調用下創建產品實例。這個角色在實現抽象建造者角色提供的方法的前提下,達到完成產品組裝,提供成品的功能。

  指導者角色:調用具體建造者角色以創建產品對象。指導者并沒有產品類的具體知識,真正擁有產品類的具體知識的是具體建造者對象。 產品角色:建造中的復雜對象。它要包含那些定義組件的類,包括將這些組件裝配成產品的接口。

  首先客戶程序創建一個指導者對象,一個建造者角色,并將建造者角色傳入指導者對象進行配置。然后,指導者按照步驟調用建造者的方法創建產品。最后客戶程序從建造者或者指導者那里得到產品。

  從建造模式的工作流程來看,建造模式將產品的組裝“外部化”到了建造者角色中來。這是和任何正規的工廠模式不一樣的——產品的創建是在產品類中完成的。

  三、實現

  實在找不到太好的例子,我認為《java與模式》中發郵件的例子還算可以。這里我將《Think in Patterns with Java》中的例子放到這里權且充個門面。媒體可以存在不同的表達形式,比如書籍、雜志和網絡。這個例子表示不同形式的媒體構造的步驟是相似的,所以可以被提取到指導者角色中去。

  import java.util.*;
  import junit.framework.*;

  //不同的媒體形式:

  class Media extends ArrayList {}
  class Book extends Media {}
  class Magazine extends Media {}
  class WebSite extends Media {}

  // 進而不含不同的媒體組成元素:

  class MediaItem {
  private String s;
  public MediaItem(String s) { this.s = s; }
  public String toString() { return s; }
  }

  class Chapter extends MediaItem {
  public Chapter(String s) { super(s); }
  }

  class Article extends MediaItem {
  public Article(String s) { super(s); }
  }

  class WebItem extends MediaItem {
  public WebItem(String s) { super(s); }
  }

  // 抽象建造者角色,它規范了所有媒體建造的步驟:

  class MediaBuilder {
  public void buildBase() {}
  public void addMediaItem(MediaItem item) {}
  public Media getFinishedMedia() { return null; }
  }

  //具體建造者角色

  class BookBuilder extends MediaBuilder {
  private Book b;
  public void buildBase() {
  System.out.println("Building book framework");
  b = new Book();
  }

  public void addMediaItem(MediaItem chapter) {
  System.out.println("Adding chapter " + chapter);
  b.add(chapter);
  }
  public Media getFinishedMedia() { return b; }
  }

  class MagazineBuilder extends MediaBuilder {
  private Magazine m;
  public void buildBase() {
  System.out.println("Building magazine framework");
  m = new Magazine();
  }

  public void addMediaItem(MediaItem article) {
  System.out.println("Adding article " + article);
  m.add(article);
  }
  public Media getFinishedMedia() { return m; }
  }

  class WebSiteBuilder extends MediaBuilder {
  private WebSite w;
  public void buildBase() {
  System.out.println("Building web site framework");
  w = new WebSite();
  }

  public void addMediaItem(MediaItem webItem) {
  System.out.println("Adding web item " + webItem);
  w.add(webItem);
  }

  public Media getFinishedMedia() { return w; }
  }

  //指導者角色,也叫上下文
  class MediaDirector {
  private MediaBuilder mb;
  public MediaDirector(MediaBuilder mb) {
  this.mb = mb; //具有策略模式相似特征的
  }

  public Media produceMedia(List input) {
  mb.buildBase();
  for(Iterator it = input.iterator(); it.hasNext();)
   mb.addMediaItem((MediaItem)it.next());
   return mb.getFinishedMedia();
  }
  };

  //測試程序——客戶程序角色

  public class BuildMedia extends TestCase {
  private List input = Arrays.asList(new MediaItem[] {
  new MediaItem("item1"), new MediaItem("item2"),
  new MediaItem("item3"), new MediaItem("item4"),
  });

  public void testBook() {
  MediaDirector buildBook = new MediaDirector(new BookBuilder());
  Media book = buildBook.produceMedia(input);
  String result = "book: " + book;
  System.out.println(result);
  assertEquals(result, "book: [item1, item2, item3, item4]");
  }

  public void testMagazine() {
  MediaDirector buildMagazine = new MediaDirector(new MagazineBuilder());
  Media magazine = buildMagazine.produceMedia(input);
  String result = "magazine: " + magazine;
  System.out.println(result);
  assertEquals(result, "magazine: [item1, item2, item3, item4]");
  }

  public void testWebSite(){
  MediaDirector buildWebSite = new MediaDirector(new WebSiteBuilder());
  Media webSite = buildWebSite.produceMedia(input);
  String result = "web site: " + webSite;
  System.out.println(result);
  assertEquals(result, "web site: [item1, item2, item3, item4]");
  }

  public static void main(String[] args) {
  junit.textui.TestRunner.run(BuildMedia.class);
  }

  }

  在實現的時候,抽象建造角色提供的接口必須足夠普遍,以適應不同的具體建造角色。對于一個建造角色來說可能某個步驟是不需要的,可以將此接口實現為空。多個產品之間可能沒有太多的共同點,可以提供一個標示接口作為抽象產品角色;也可以不提供抽象產品角色,這時要將提供產品的接口從抽象建造角色里面去掉,不然就會編譯出問題。

  四、應用優點

  建造模式可以使得產品內部的表象獨立變化。在原來的工廠方法模式中,產品內部的表象是由產品自身來決定的;而在建造模式中則是“外部化”為由建造者來負責。這樣定義一個新的具體建造者角色就可以改變產品的內部表象,符合“開閉原則”。

  建造模式使得客戶不需要知道太多產品內部的細節。它將復雜對象的組建和表示方式封裝在一個具體的建造角色中,而且由指導者來協調建造者角色來得到具體的產品實例。

  每一個具體建造者角色是毫無關系的。

  建造模式可以對復雜產品的創建進行更加精細的控制。產品的組成是由指導者角色調用具體建造者角色來逐步完成的,所以比起其它創建型模式能更好的反映產品的構造過程。

  五、擴展

  建造模式中很可能要用到組成成品的各種組件類,對于這些類的創建可以考慮使用工廠方法或者原型模式來實現,在必要的時候也可以加上單例模式來控制類實例的產生。但是要堅持一個大前提就是要使引入的模式給你的系統帶來好處,而不是臃腫的結構。 建造模式在得到復雜產品的時候可能要引用多個不同的組件,在這一點上來看,建造模式和抽象工廠模式是相似的。可以從以下兩點來區分兩者:創建模式著重于逐步將組件裝配成一個成品并向外提供成品,而抽象工廠模式著重于得到產品族中相關的多個產品對象;抽象工廠模式的應用是受限于產品族的(具體參見《深入淺出工廠模式》),建造模式則不會。

  由于建造模式和抽象工廠模式在實現功能上相似,所以兩者使用的環境都比較復雜并且需要更多的靈活性。 建造模式中可能要使用到不同“大小”的組件類,因此這時也經常和合成模式在一起使用。


主站蜘蛛池模板: 欧美在线看欧美高清视频免费 | 人人爱人人看 | 三级自拍 | 日韩艳片| 日本三级精品 | 日韩伦理网在线视频 | 亚洲国产高清精品线久久 | 青青青久97在线观看香蕉 | 四虎午夜 | 青青草a国产免费观看 | 青青青久97在线观看香蕉 | 色欧美亚洲 | 在线亚洲精品 | 一区在线视频 | 日韩毛片在线视频 | 四虎国产精品免费五月天 | 亚洲精品中文字幕午夜 | 亚洲第一视频 | 婷婷六月色 | 亚洲精品综合在线 | 欧美一区二区三区精品国产 | 日韩精品视频在线播放 | 欧美一区亚洲 | 青草青视频 | 性欧美xxxx性| 五月综合激情久久婷婷 | 日日干日日爽 | 青青草a | 欧美整片第一页 | 伊人影视网 | 天天干天天操天天碰 | 欧美综合图区亚洲综合图区 | 四虎4hu永久免费国产精品 | 欧美一卡二卡三卡四卡 | 五月天婷婷色综合 | 天天干天天插天天射 | 亚洲 另类色区 欧美日韩 | 天天爱天天做天天爽夜夜揉 | 她也啪在线视频 | 天堂中文在线资源 | 青青色综合 |