中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java如何實現工廠模式

發布時間:2021-08-07 14:09:33 來源:億速云 閱讀:123 作者:小新 欄目:編程語言

這篇文章將為大家詳細講解有關Java如何實現工廠模式,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

具體如下:

一、 簡單工廠

先來思考一個問題。我們平時寫程序時,會有這種情況,A對象里面需要調用B對象的方法,這時我們使用的一般是new關鍵字來創建一個B實例,然后調用B實例的方法。這種做法的壞處在于:A類的方法實現直接調用了B類的類名(這種方式也被稱為硬編碼耦合),一旦系統需要重構:需要使用C類來代替B類時,程序就不得不修改A類代碼,如果應用中有100個或者10000個類以硬編碼方式耦合了B類,則需要修改100個、10000個地方,這顯然是一種非常可怕的事情。

換一個角度來看這個問題:對已A對象而言,它只需要調用B對象的方法,并不關心B對象的實現、創建過程,考慮讓B類實現一個IB接口,而A類只需要與IB接口耦合——A類并不直接使用new關鍵字來創建B實例,而是重新定義一個工廠類:IBFactory,由該工廠類負責創建IB實例,而A類用過調用IBFactory工廠的方法來得到IB的實例。通過以上設計:需要使用C類代替B類,則只需要讓C類也實現IB接口,并改寫IBFactory工廠中創建IB實例的實現代碼,讓該工廠產生C實例即可。這種將多個類對象交給工廠類來生成的設計方式叫做簡單工廠模式。

以下是簡單工廠模式的代碼:

/**
 * 簡單工廠模式
 *
 * 需要工廠生產的對象實例所實現的共同的接口
 * 發型接口
 * @author Administrator
 *
 */
public interface Hair {
  /**
   * 畫發型
   */
  public void draw();
}
/**
 * 左偏分發型
 * @author Administrator
 *
 */
public class LeftHair implements Hair {
  @Override
  public void draw() {
    System.out.println("----------------畫左偏分發型-----------------");
  }
}
/**
 * 右偏分發型
 * @author Administrator
 *
 */
public class RightHair implements Hair {
  @Override
  public void draw() {
    System.out.println("-----------------畫右偏分發型------------------");
  }
}
/**
 * 生產發型的工廠
 * 要生產什么發型 只需在這里改就行了
 * @author Administrator
 *
 */
public class HairFactory {
  public Hair getHair() {
    return new LeftHair();
    //return new RightHair();
  }
}
/**
 * 客戶端測試類
 * @author Administrator
 *
 */
public class HairTest {
  public static void main(String[] args) {
    HairFactory factory = new HairFactory();
    Hair hair = factory.getHair();
    hair.draw();
  }
}

可以看到,如果想把HairTest里面生成的LeftHair改成RightHair,只需修改HairFactory里面getHair方法的實現即可。

使用簡單工廠模式的優勢在于:讓對象的調用者和對象的創建過程分離,當對象調用者需要對象時,直接向工廠請求即可,從而避免了對象的調用者與對象實現類以硬編碼方式耦合,以提高系統的可維護性、可擴展性。當然,工廠模式也有一個小小的缺陷,當產品修改時,工廠類也要做相應的修改,此處可使用策略模式進行解決,下面是代碼。

public interface HairBuilder {
  /**
   * 制造發型
   * @return
   */
  public Hair getHair();
}
public class LeftHairBuilder implements HairBuilder {
  @Override
  public Hair getHair() {
    return new LeftHair();
  }
}
public class RightHairBuilder implements HairBuilder {
  @Override
  public Hair getHair() {
    return new RightHair();
  }
}
public class HairFactory {
  private HairBuilder hairBuilder;
  public HairFactory(HairBuilder hairBuilder) {
    this.hairBuilder = hairBuilder;
  }
  public void setHairBuilder(HairBuilder hairBuilder) {
    this.hairBuilder = hairBuilder;
  }
  public Hair getHair() {
    return hairBuilder.getHair();
  }
}
public class HairTest {
  public static void main(String[] args) {
//   HairBuilder builder = new LeftHairBuilder();
    HairBuilder builder = new RightHairBuilder();
    HairFactory factory = new HairFactory(builder);
    Hair hair = factory.getHair();
    hair.draw();
  }
}

這種做法的好處是無需再去修改工廠類,將工廠里面的創建對量邏輯根據不同的策略抽象出來,程序需要創建什么對象,只需網工廠中傳入相應的builder即可。

二、工廠方法

在簡單工廠模式中,系統使用工廠類生產所有產品實例,且該工廠類決定生產哪個類的實例,即工廠類負責所有的邏輯判斷、實例創建等工作。

如果不想再工廠類中進行邏輯判斷,程序可以為不同的產品類提供不同的工廠,不同的工廠類生產不同的產品,無需再工廠類中進行復雜的邏輯判斷。這就有點類似于上面的簡單工廠模式結合策略模式,不同的是前者只有一個工廠,后者需要有多個工廠。下面是工廠方法模式的代碼。

/**
 * 工廠方法模式
 * 需要工廠生產的對象實例所實現的共同的接口
 * @author Administrator
 *
 */
public interface Person {
  public void drawPerson();
}
public class Man implements Person {
  @Override
  public void drawPerson() {
    System.out.println("---------------------draw a man--------------------");
  }
}
public class Women implements Person {
  @Override
  public void drawPerson() {
    System.out.println("--------------------draw a women---------------------");
  }
}
/**
 * 生產人的工廠
 * @author Administrator
 *
 */
public interface PersonFactory {
  //生產人
  public Person getPerson();
}
/**
 * 生產man的工廠
 * @author Administrator
 *
 */
public class ManFactory implements PersonFactory {
  @Override
  public Person getPerson() {
    return new Man();
  }
}
/**
 * 聲場women的工廠
 * @author Administrator
 *
 */
public class WomenFactory implements PersonFactory {
  @Override
  public Person getPerson() {
    return new Women();
  }
}
/**
 * 客戶端測試類
 * @author Administrator
 *
 */
public class PersonTest {
  public static void main(String[] args) {
//   PersonFactory factory = new ManFactory();
    PersonFactory factory = new WomenFactory();
    Person person = factory.getPerson();
    person.drawPerson();
  }
}

這種的典型的特點就是在客戶端代碼中根據不同的工廠生產其對應的產品,不必把復雜的邏輯都放在工廠類里面判斷。這種實現有一個很明顯的缺陷,就是客戶端與工廠類進行了耦合。

三、抽象工廠

采用上面的工廠方法的設計架構,客戶端代碼成功與被調用對象的實現類分離,但帶來了另一種耦合:客戶端代碼與不同的工廠類耦合。為了解決這種耦合的問題,考慮在增加一個工廠類,用來生成工廠實例,實現生產產品的工廠與客戶端分離,這種設計方式被稱為抽象工廠模式。下面是抽象工廠模式的代碼

/**
 * 抽象工廠模式
 * 生產PersonFactory的工廠
 * @author Administrator
 *
 */
public class PersonFactoryFactory {
  public static PersonFactory getPersonFactory(String type) {
    if(type.equalsIgnoreCase("man")) {
      return new ManFactory();
    } else {
      return new WomenFactory();
    }
  }
}
/**
 * 客戶端測試類
 * @author Administrator
 *
 */
public class PersonTest {
  public static void main(String[] args) {
    PersonFactory factory = PersonFactoryFactory.getPersonFactory("man");
    Person person = factory.getPerson();
    person.drawPerson();
  }
}

關于“Java如何實現工廠模式”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

浮梁县| 乌兰县| 新营市| 阆中市| 德保县| 张家界市| 仲巴县| 临桂县| 青州市| 兴城市| 甘德县| 西林县| 东乡| 清水县| 湖口县| 林芝县| 宁海县| 嘉义县| 邹城市| 托克托县| 略阳县| 大宁县| 扶沟县| 镇康县| 麻阳| 平顺县| 武义县| 庆云县| 湘阴县| 鹿邑县| 商水县| 平果县| 兴业县| 临朐县| 洛宁县| 嵊州市| 蛟河市| 朝阳市| 华坪县| 遂平县| 西青区|