工廠模式

来源:http://www.cnblogs.com/mercuryli/archive/2016/03/20/5290970.html
-Advertisement-
Play Games

工廠模式分為三種模式,分別為: 下麵就分別介紹一下這三種設計模式: 簡單工廠模式就是由一個工廠類根據傳入的參數量,來決定創建哪一種產品類的實例。(仔細理解這句話,非常重要) 結構圖: 上圖涉及三個類: 源代碼實例: 抽象產品類(Product): Product.java: 具體產品類(Concre


工廠模式分為三種模式,分別為:

  •  簡單工廠(Simple Factory)模式:又稱靜態工廠方法模式(Static Factory Method Pattern)
  • 工廠方法(Factory Method)模式:又稱多態性工廠模式(Polymorphic Factory Pattern)或虛擬構造子模式(Virtual Construct Pattern)
  • 抽象工廠(Abstract Factory)模式:又稱工具箱模式(Kit或Tookit)

下麵就分別介紹一下這三種設計模式:

  1.  簡單工廠模式(Simple Factory):

  簡單工廠模式就是由一個工廠類根據傳入的參數量,來決定創建哪一種產品類的實例。(仔細理解這句話,非常重要)

結構圖:

 

上圖涉及三個類:

  • 工廠類(Creator):擔任工廠模式的核心。工廠類在客戶端的調用下直接創建對象,它往往由一個具體類java類實現。
  • 抽象產品類(Product):具體產品類的介面或抽象類。
  • 具體產品類(ConcreteProduct):工廠方法模式所創建的任何角色都是這個角色的實例

源代碼實例:

抽象產品類(Product):

Product.java:

public interface Product {
}

具體產品類(ConcreteProduct):

ConcreteProductA.java:

public class ConcreteProductA implements Product{
    public ConcreteProductA(){
        System.out.println("具體產品類A");
    }
}

ConcreteProductB.java:

public class ConcreteProductB implements Product{
    public ConcreteProductB(){
        System.out.println("具體產品類B");
    }
}

工廠類(Creator):

Creator.java:

public class Creator {
    
    public static Product factory(String which){
        if (which.equalsIgnoreCase("ConcreteProductA")) {
            return new ConcreteProductA();
        }else if (which.equalsIgnoreCase("ConcreteProductB")) {
            return new ConcreteProductB();
        }else {
            return null;
        }
    }
}

客戶端:

public class Client {
    public static void  main(String[] args){
        Creator creator = new Creator();
        creator.factory("ConcreteProductB");
        creator.factory("ConcreteProductA");
        
    }
}

輸出:

具體產品類B
具體產品類A

    2、工廠方法模式(Factory Method)

     工廠方法模式中核心工廠類變為一個抽象類,僅負責給出具體工廠子類必須實現的介面,不再接觸哪一個產品類被實例化這種細節。

結構中成員類和上面差不多,:

  • 抽象工廠類(Creator):為所有具體工廠類提供介面。
  • 具體工廠類(ConcreteCreator):擔任這個角色是實現了抽象工廠介面的具體java類,並且受到應用程式的調用來創建產品。
  • 抽象產品(Product)
  • 具體產品(ConcreteProduct)

抽象方法將某一個產品和一個工廠進行了綁定,這是他與另外兩個工廠模式的區別。下麵註意看代碼:源代碼:

抽象產品(Product):

public interface Product {

}

 

 具體產品(ConcreteProduct)類:

ConcreProductA.java:

public class ConcreteProductA implements Product{
    public ConcreteProductA(){
        System.out.println("具體產品類A");
    }
}

 

ConcreProductB.java:

public class ConcreteProductB implements Product{
    public ConcreteProductB(){
        System.out.println("具體產品類B");
    }
}

 

抽象工廠類(Creator):

Creator.java:

public interface Creator {
    public Product factory();
}

 

具體工廠類(ConcreteCreator):

ConcreteCreatorA.java:

public class ConcreteCreatorA implements Creator{

    @Override
    public Product factory() {
        return new ConcreteProductA();
    }
}

 

ConcreteCreatorB.java:

public class ConcreteCreatorB implements Creator{
    
    @Override
    public Product factory() {
        return new ConcreteProductB();
    }
    
}

客戶端:

public class Client {

    public static void main(String[] args){
        Creator creatorA = new ConcreteCreatorA();
        creatorA.factory();
        Creator creatorB = new ConcreteCreatorB();
        creatorB.factory();
    }
}

 

輸出:

具體產品類A
具體產品類B

 

    3、抽象工廠模式(Abstract Factory)

  抽象工廠模式是對象的創建模式,他是工廠方法模式的進一步擴展。使用抽象工廠模式,可以創建來自不同工廠的各種產品。

 

 

 

 

結構圖中的角色:

  • 抽象工廠類(Creator)
  • 具體工廠類(ConcreteCreator)
  • 抽象產品(Product)
  • 具體產品(ConcreteProduct)

源代碼:

抽象產品類(Product):

ProductA.java

public interface ProductA {
}

 

ProductB.java

public interface ProductB {
}

 

具體產品類(ConcreteProduct):

ProductA1.java

public class ProductA1 implements ProductA{
    
    public ProductA1(){
        System.out.println("具體產品A1");
    }
}

 

productA2.java、productB1.java、productB2.java與上類似,不在列出。

抽象工廠類(Creator):

Creator.java

public interface Creator {
    
    public ProductA factoryA();
    public ProductB factoryB();
}

 

 具體工廠類(ConcreteCreator):

ConcreteCreator1.java

public class ConcretCreator1 implements Creator{

    public ConcretCreator1(){
        System.out.println("具體工廠1:");
    }
    public ProductA factoryA(){
        return new ProductA1();
    }
    public ProductB factoryB(){
        return new ProductB1();
    }

}

 

ConcreteCreator2.java

public class ConcretCreator2 implements Creator{

    public ConcretCreator2(){
        System.out.println("具體工廠2:");
    }
    public ProductA factoryA() {
        return new ProductA2();
    }

    public ProductB factoryB() {
        return new ProductB2();
    }

}

 

 客戶端:

public class client {
    public static void main(String[] args){
        //抽象工廠1
        Creator creator1 = new ConcretCreator1();
        creator1.factoryA();
        creator1.factoryB();
        Creator creator2 = new ConcretCreator2();
        creator2.factoryA();
        creator2.factoryB();
    }
}

 

 輸出:

具體工廠1:
具體產品A1
具體產品B1
具體工廠2:
具體產品A2
具體產品B2

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本實驗主要是實現蜂鳴器的操作,蜂鳴器的操作是非常簡單的,只有把簡單的事情做好,方可談其他複雜的事。本實驗部分會利用verilog一些巨集定義語句,其實在VGA實驗部分已經出現過,這裡為了鞏固,再次調用相關巨集定義命令,已達到最大化的可移植性,請讀者務必掌握這種用法,很實用。 談及蜂鳴器或者LED,多多少
  • 這幾天呢,公司風波再起,去年一年公司CTO換啦4任,CEO換啦三個,這不剛來個新老大,感覺還不錯,卻沒乾過3個月又要走,索性趁老大們走來走去的時候,就給自己空出來,稍稍總結一下剛寫的一個日誌服務組件中用到的RabbitMQ,在.net中的實戰中應用。 首先不去討論我的日誌組件怎麼樣。因為有些日誌需要
  • 少爺菜鳥一枚,求輕噴。 今天在網上無意間看到一道面試題,感覺挺有意思的,題目是這樣:"請用任意一種面向對象語言實現一個電腦控制台程式,要求輸入兩個數和運算符號,輸出結果”。 第一遍的時候還在想,居然還有這麼簡單的面試題?花了幾分鐘敲了一下這個程式,代碼如下(為了方便,代碼本身不規範,很多情況並未考
  • oauth2.0 sso jackical
  • 在平時寫程式的時候往往會遇到這樣的需求,對於某些資源我們只想讓其只能由一個對象進行訪問,從而保證其完整性。比如,配置文件,工具類,線程池,緩存,日誌對象等。對這些資源進行訪問的對象我們只需要一個,當能對其進行讀寫的對象多了的時候就可能由於邏輯上的問題導致了很多意想不到的結果。在這個的背景下,結合了面...
  • 註冊組件以後,通過容器或 ILifetimeScope 的 Resolve 方法解析服務: 請註意,本例使用 ILifetimeScope 解析服務,而不是直接從容器解析。儘管可以從根容器直接解析組件,但是,某些情況下導致記憶體泄露。建議始終從 ILifetimeScope對象解析組件,以確保服務的實
  • 上一篇開源任務管理平臺TaskManager介紹發佈後,有網友聯繫我看看能不能做個後臺管理界面,方便管理系統中所有的任務。由於時間和技術問題1.0版本的時候,新增了一個3分鐘讀取配置文件動態修改任務的功能,不過總體來說還是不直觀,操作不便捷。剛好最近接觸到了Owin,可以實現自己的宿主程式運行Web
  • 常說的工廠模式一般認為有三種:簡單工廠、工廠方法模式、抽象工廠模式。其中簡單工廠嚴格上來說不是一種設計模式,而被認為是一種好的編碼習慣/風格。 簡單工廠 簡單工廠的本質就是封裝變化的代碼,使客戶代碼將要面臨的改變變少。而且被封裝的代碼也有了更好的復用性,比如服務多個客戶端或者被繼承/包裝等工具來擴展
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...