設計模式-實踐-工廠模式

来源:http://www.cnblogs.com/GGMF/archive/2016/05/04/5458381.html
-Advertisement-
Play Games

前言 這篇博客的目的是對項目中偶爾碰到的應用設計模式的代碼積累一下。 我認為針對於設計模式的學習,通過看書、看例子只能瞭解概念,而重要的是如何把概念應用到實際的項目開發中。 而且我想提醒大家的是,學習設計模式時,千萬不要拘泥於書上的內容,形成定式思維,這樣對於其他源碼理解會出現一層自然屏障,理解起來 ...


前言

這篇博客的目的是對項目中偶爾碰到的應用設計模式的代碼積累一下。

 

我認為針對於設計模式的學習,通過看書、看例子只能瞭解概念,而重要的是如何把概念應用到實際的項目開發中。

而且我想提醒大家的是,學習設計模式時,千萬不要拘泥於書上的內容,形成定式思維,這樣對於其他源碼理解會出現一層自然屏障,理解起來很困難。

大家在看JDK源碼和Spring源碼時會發現,很少照搬書上的內容,都是靈活運用。

 

這也是我計劃寫這類博客的原因,希望通過項目中的實際需求去理解,並應用設計模式!

 

開篇之作--簡單工廠模式的應用

 

需求:我們項目中有個消費記錄解析上傳的功能,我們需要給客戶端開發一個介面。客戶端調用介面,將多條消費記錄以參數傳入介面,然後介面

解析參數中的數據,並將數據存儲到資料庫中。項目中存在多種業務,一種業務對應一種解析規則,以後還可能會新加業務類型。

 

分析:針對於這個需求,如果沒有學習過設計模式,可能這樣實現。第一種,項目當前有4種業務,那麼就寫4個介面,一個介面實現一種解析規則,

客戶端根據不同的規則調用不同的介面;第二種,改進些,那麼就給客戶端暴漏一個介面,客戶端將類型傳入介面,方法中根據類型調用不同的解析規則。

那麼第一種方法的問題是什麼呢?項目有4種業務寫4個介面,如果有10個業務就寫10個介面,這些介面實現的業務功能又是一樣的,那麼這是很明顯

的代碼重覆,介面冗餘,成功的給項目重構挖了一個坑。

第二種方法呢,確實解決了上面說的問題,但是實現上又導致了介面對規則的依賴,所以也是不可取的。

那麼我們項目中是如何實現的呢?請往下看…

 

項目實現:

註:代碼主要表達思想,大家不要摳具體的類名、標簽名等等,主要理解實現思路,本人以前就經常犯鑽牛角尖的毛病!

1、首先是暴漏給客戶端的介面

public class ConsumeHistoryAction extends BaseExecutableAction{

    private Logger logger = LoggerFactory.getLogger(this.getClass());
    
    @Autowired
    private ConsumeHistoryService consumeHistoryService;
    
    @Autowired
    private TransDetailResolverFactory transDetailResolverFactory;
    
    public void upload(Map map) throws CoreException{
        //  獲取業務類型
        String type = map.get(“type”);

        // 獲取要解析的數據
        String data = map.get(“data”);

        // 根據業務類型獲取解析規則類(一個業務類型對應一個解析類)
        TransDetailResolver resolver = transDetailResolverFactory.getResolver(type);

        if(resolver==null){
            logger.error("No TransDetailResolver defined for {}", type);
            return;
        }

        // 解析數據,將數據放到一個實體類中
        ConsumeHistory consumeRecord = resolver.resolver(data);

        // 保存數據到資料庫
        consumeHistoryService.upload(consumeRecords);
    }
}

 

2、解析工廠類的實現

public class TransDetailResolverFactory {

    // 通過spring配置,將具體的業務類型與解析規則類的對應關係註入進來
    // 這樣就有效避免了工廠類和規則類之間的依賴
    private Map<String,TransDetailResolver> resolvers = new HashMap<String,TransDetailResolver>();
    
    public interface TransDetailResolver {
        
        public ConsumeHistory resolver(String str);
    }
    
    public void setResolvers(Map<String, TransDetailResolver> resolvers) {
        this.resolvers = resolvers;
    }

    public TransDetailResolver getResolver(String aid){
        // 其實這塊依賴的處理,也可以通過反射來實現
         TransDetailResolver resolver = resolvers.get(aid);
        return resolver;
    }
    
}

 

 

3、依賴關係的配置

<x:bean class="com.xxx.TransDetailResolverFactory">
    <x:property name="resolvers">
        <x:map>
            // 本項目的業務類型其實是一串CODE碼
            <x:entry key="1001">
                <x:bean class="com.xxx.consumehistory.aaaResolver">
                </x:bean>
            </x:entry>
            <x:entry key="1002">
                <x:bean class="com.xxx.consumehistory.bbbResolver">
                </x:bean>
            </x:entry>
            <x:entry key="1003">
                <x:bean class="com.xxx.consumehistory.cccResolver">
                </x:bean>
            </x:entry>
        </x:map>
    </x:property>
</x:bean>

 

4、解析規則類的實現

這個我就不具體上代碼了,就是根據具體的業務規則實現代碼的解析規則就可以了。

特別註意的是,這個類一定要實現工廠類中的介面,為什麼要實現?這個問題留給閱讀的同學思考吧!嘿嘿嘿!

 

總結:以上就是具體的實現思路了,雖然簡單,但是代碼結構很清晰,如果未來要加一種業務類型,只需要創建對應的解析規則類,再修改下配置

文件就搞定了,其他的代碼都不需要改動。

首篇博客,廢話較多,以後會直接上乾貨!!!

有哪些不足,請大家多多指點!!!


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

-Advertisement-
Play Games
更多相關文章
  • 簡單工廠模式是屬於創建型模式,又叫做靜態工廠方法(Static Factory Method)模式,但不屬於23種GOF設計模式之一。簡單工廠模式是由一個工廠對象決定創建出哪一種產品類的實例。簡單工廠模式是工廠模式家族中最簡單實用的模式,可以理解為是不同工廠模式的一個特殊實現。 簡單工廠模式的UML ...
  • 解釋器模式(Interpreter) 定義 解釋器模式(Interpreter),給定一個語言,定義它的文法的一種表示,並定義一個解釋器,這個解釋器使用該表示來解釋語言中的句子。 類圖 描述 Expression:抽象表達式,聲明一個所有的具體表達式都需要實現的抽象介面;這個介面主要是一個inter ...
  • 1.意圖 定義一個用於創建對象的介面,讓子類決定實例化哪一個類。Factory Method使一個類的實例化延遲到其子類。 2.動機 框架使用抽象類定義和維護對象之間的關係。這些對象的創建通常也由框架負責。 3.適用性 當一個類不知道它所必須創建的對象的類的時候。 當一個類希望由它的子類來指定它所創 ...
  • 主要利用工廠模式來實現了一個計算器,將加減乘除操作分離了開來,實現了低耦合的目標。 ...
  • 使用嵌套的 ILifetimeScope 解析服務 Autofac 被設計為跟蹤(track)和清理(dispose)資源。為確保資源被正確處理,務必將長時間運行的應用程式分成小的工作單元 (請求或事務),服務的解析應在工作單元級別的生命周期範圍中進行。為 asp.net 實現的每個請求一個生命周期 ...
  • 一、框架概述 1.1 框架的意義與作用: 所謂框架,就是把一些繁瑣的重覆性代碼封裝起來,使程式員在編碼中把更多的經歷放到業務需求的分析和理解上面。特點:封裝了很多細節,程式員在使用的時候會非常簡單。1.2 三大框架:Struts2,Hibernate,Spring1.3 如何學好框架由於框架中細節很 ...
  • 長久以來,伺服器端的高層架構大體被區分為對立的兩類:SOA(Service-oriented architecture)以及 AIO(All in one)。SOA 將一個完整的應用分割為相互獨立的服務,每個服務提供一個單一標準功能
  • 《Clean Code》是一本令人印象深刻的書,它將編碼當成寫作,強調代碼應當像文章一樣清晰準確而不是晦澀難懂。 同時作者給出了操作性很強的編碼建議: ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...