主頁 > 軟體設計 > 如何理解這6種常見設計模式?

如何理解這6種常見設計模式?

2023-01-21 07:41:06 軟體設計

 

導讀:設計模式能夠幫助我們優化代碼結構,讓代碼更優雅靈活,有哪些常見的設計模式?如何合理運用?本文分享作者對工廠模式、單例模式、裝飾模式、策略模式、代理模式和觀察者模式的理解,介紹每種模式的模式結構、優缺點、適用場景、注意實作及代碼實作,

一  前言
最近在改造一些歷史的代碼,發現一個很明顯的特點,大部分代碼是記敘文,按照事件的發展程序將故事平鋪直敘的講解出來,
這種方式的好處是比較符合人類的思維習慣,一條主線講到底,代碼閱讀起來沒有太大難度,只要順著藤就能摸到瓜,但是缺點也很明顯,一旦故事線中需要插入一些新的元素,比如:加入一個新的人物角色、新的時間線,都會需要大量更改故事線以配合這個新元素的融入,甚至對原有文章造成破壞性的影響,
為了解決這個問題,人們總結出了很多種文章結構,例如:總-分結構,并列結構,總-分-總結構等等,有了這些結構,在加入新元素的時候,甚至不必考慮新元素與原故事情節的關聯性,直接單拉一個分支故事線獨立去講就好了,只要能夠在整體故事結束前,與匯聚到主線故事就可以了(是不是很像git?),
在軟體開發領域,也有很多這樣的非常有用的實踐總結,我們稱之為設計模式,對于設計模式,大家都不陌生,隨便找個人,估計都能講出N個設計模式來,但是除了這些設計模式的概念,很多人不知道如何靈活運用這些設計模式,所以借這篇文章和大家共同學習設計模式的思想,
二  理解設計模式
 
我盡量用最通俗易懂的示例和語言來講述我理解的設計模式,希望能對大家有所幫助,
另外也無需精通所有的設計模式,只要能夠融匯貫通常見的設計模式,就能讓你的代碼變得優雅,就像程咬金只會三板斧,但是熟練度無人能及,照樣能橫行天下,

 

1  工廠模式(Factory)
簡單工廠(Simple Factory)
小明追妹子的時候,請她喝了不少咖啡,她愛喝卡布奇諾,每次去咖啡店,只要跟服務員說“來杯卡布奇諾”就行了,雖然各家的口味有些不同,但是不管是星爸爸還是Costa,都能夠提供卡布奇諾這種咖啡,這里的星爸爸和Costa就是生產咖啡的工廠,
(1)簡單工廠模式結構
簡單工廠模式包含如下角色:
  • Factory:工廠角色-負責實作創建所有實體的內部邏輯.

  • Product:抽象產品角色-是所創建的所有物件的父類,負責描述所有實體所共有的公共介面,

  • ConcreteProduct:具體產品角色-是創建目標,所有創建的物件都充當這個角色的某個具體類的實體,

結構圖:
時序圖:
圖片
(2)優缺點
  • 優點:客戶類和工廠類分開,消費者任何時候需要某種產品,只需向工廠請求即可,消費者無須修改就可以接納新產品,

  • 缺點:是當產品修改時,工廠類也要做相應的修改,

工廠方法(Factory Method)
以前經常帶老婆去優衣庫(簡單工廠)買衣服,就那么多款式,逛的次數多了,她就煩了,后來我改變策略,帶老婆去逛商場(抽象工廠),商場里有各式品牌的店鋪,不用我管,她自己就能逛上一整天,
區別于簡單工廠,核心工廠類(商場)不再負責所有產品的創建,而是將具體創建的作業交給子類(服裝店)去做,成為一個抽象工廠角色,僅負責給出具體工廠類必須實作的介面(門店),而不接觸哪一個產品類應當被實體化這種細節,
(1)工廠方法模式結構
工廠方法模式包含如下角色:
  • Product:抽象產品

  • ConcreteProduct:具體產品

  • Factory:抽象工廠

  • ConcreteFactory:具體工廠

結構圖:
圖片
時序圖:
圖片
工廠模式總結
(1)適用場景
輸出的產品是標準品,誰來做都可以,
(2)舉例
常見的資料庫連接工廠,SqlSessionFactory,產品是一個資料庫連接,至于是oracle提供的,還是mysql提供的,我并不需要關心,因為都能讓我通過sql來操作資料,
(3)注意事項
專案初期,軟體結構和需求都沒有穩定下來時,不建議使用此模式,因為其劣勢也很明顯,增加了代碼的復雜度,增加了呼叫層次,增加了記憶體負擔,所以要注意防止模式的濫用,
(4)簡單實作
package FactoryMethod;
public class FactoryPattern
{
    public static void main(String[] args)
{
        Factory factory = new ConcreteFactoryA();
        Product product = factory.createProduct();
        product.use();
    }
}
//抽象產品:提供了產品的介面
interface Product
{
    public void use();
}
//具體產品A:實作抽象產品中的抽象方法
class ConcreteProductA implements Product
{
    public void use()
{
        System.out.println("具體產品A顯示...");
    }
}
//具體產品B:實作抽象產品中的抽象方法
class ConcreteProductB implements Product
{
    public void use()
{
        System.out.println("具體產品B顯示...");
    }
}
//抽象工廠:提供了廠品的生成方法
interface Factory
{
    public Product createProduct();
}
//具體工廠A:實作了廠品的生成方法
class ConcreteFactoryA implements AbstractFactory
{
    public Product createProduct()
{
        System.out.println("具體工廠A生成-->具體產品A.");
        return new ConcreteProductA();
    }
}
//具體工廠B:實作了廠品的生成方法
class ConcreteFactoryB implements AbstractFactory
{
    public Product createProduct()
{
        System.out.println("具體工廠B生成-->具體產品B.");
        return new ConcreteProductB();
    }
}

 

2  單例模式(Singleton)
韋小寶有7個老婆,但是每個都只有他這一個老公,他的所有老婆叫老公時,指的都是他,他就是一個單例,
單例模式結構
單例模式包含如下角色:
  • Singleton:單例

結構圖:
圖片
時序圖:
圖片
優缺點
  • 優點:全域只有一個實體,便于統一控制,同時減少了系統資源開銷,

  • 缺點:沒有抽象層,擴展困難,

應用場景
適合需要做全域統一控制的場景,例如:全域唯一的編碼生成器,
注意事項
只對外提供公共的getInstance方法,不提供任何公共建構式,
簡單實作

public class Singleton
{
    private static volatile Singleton instance=null;    //保證 instance 在所有執行緒中同步
    private Singleton(){}    //private 避免類在外部被實體化
    public static synchronized Singleton getInstance()
{
        //getInstance 方法前加同步
        if(instance == null)
        {
            instance = new Singleton();
        }
        return instance;
    }
}

 

3  裝飾模式(Decorator)
大學畢業,想要送給室友一個有紀念意義的禮物,就找到一張大家的合照,在上面寫上“永遠的兄弟!”,然后拿去禮品店裝了個相框,再包上禮盒,這里的我和禮品店都是裝飾器,都沒有改變照片本身,卻都讓照片變得更適合作為禮物送人,
裝飾模式結構
裝飾模式包含如下角色:
  • Component:抽象構件

  • ConcreteComponent:具體構件

  • Decorator:抽象裝飾類

  • ConcreteDecorator:具體裝飾類

結構圖:
時序圖:
優缺點
  • 優點:比繼承更加靈活(繼承是耦合度很大的靜態關系),可以動態的為物件增加職責,可以通過使用不同的裝飾器組合為物件擴展N個新功能,而不會影響到物件本身,

  • 缺點:當一個物件的裝飾器過多時,會產生很多的裝飾類小物件和裝飾組合策略,增加系統復雜度,增加代碼的閱讀理解成本,

適用場景
  • 適合需要(通過配置,如:diamond)來動態增減物件功能的場景,

  • 適合一個物件需要N種功能排列組合的場景(如果用繼承,會使子類數量爆炸式增長)

注意事項
  • 一個裝飾類的介面必須與被裝飾類的介面保持相同,對于客戶端來說無論是裝飾之前的物件還是裝飾之后的物件都可以一致對待,

  • 盡量保持具體構件類Component作為一個“輕”類,也就是說不要把太多的邏輯和狀態放在具體構件類中,可以通過裝飾類,

簡單實作
package decorator;
public class DecoratorPattern
{
    public static void main(String[] args)
{
        Component component = new ConcreteComponent();
        component.operation();
        System.out.println("---------------------------------");
        Component decorator = new ConcreteDecorator(component);
        decorator.operation();
    }
}
//抽象構件角色
interface  Component
{
    public void operation();
}
//具體構件角色
class ConcreteComponent implements Component
{
    public ConcreteComponent()
{
        System.out.println("創建具體構件角色");       
    }   
    public void operation()
{
        System.out.println("呼叫具體構件角色的方法operation()");           
    }
}
//抽象裝飾角色
class Decorator implements Component
{
    private Component component;   
    public Decorator(Component component)
{
        this.component=component;
    }   
    public void operation()
{
        component.operation();
    }
}
//具體裝飾角色
class ConcreteDecorator extends Decorator
{
    public ConcreteDecorator(Component component)
{
        super(component);
    }   
    public void operation()
{
        super.operation();
        addBehavior();
    }
    public void addBehavior()
{
        System.out.println("為具體構件角色增加額外的功能addBehavior()");           
    }
}

 

4  策略模式(Strategy)
男生追妹子時,一般都會用到這種模式,常見的策略有這些:約會吃飯;看電影;看演唱會;逛街;去旅行……,雖然做的事情不同,但可以相互替換,唯一的目標都是捕獲妹子的芳心,
策略模式結構
  • Context: 環境類

  • Strategy: 抽象策略類

  • ConcreteStrategy: 具體策略類

結構圖:
時序圖:
圖片
優缺點
  • 優點:策略模式提供了對“開閉原則”的完美支持,用戶可以在不修改原有系統的基礎上選擇演算法或行為,干掉復雜難看的if-else,

  • 缺點:呼叫時,必須提前知道都有哪些策略模式類,才能自行決定當前場景該使用何種策略,

試用場景
一個系統需要動態地在幾種可替換演算法中選擇一種,不希望使用者關心演算法細節,將具體演算法封裝進策略類中,
注意事項
一定要在策略類的注釋中說明該策略的用途和適用場景,
簡單實作
package strategy;
public class StrategyPattern
{
    public static void main(String[] args)
{
        Context context = new Context();
        Strategy strategyA = new ConcreteStrategyA();
        context.setStrategy(strategyA);
        context.algorithm();
        System.out.println("-----------------");
        Strategy strategyB = new ConcreteStrategyB();
        context.setStrategy(strategyB);
        context.algorithm();
    }
}
//抽象策略類
interface Strategy
{   
    public void algorithm();    //策略方法
}
//具體策略類A
class ConcreteStrategyA implements Strategy
{
    public void algorithm()
{
        System.out.println("具體策略A的策略方法被訪問!");
    }
}
//具體策略類B
class ConcreteStrategyB implements Strategy
{
  public void algorithm()
{
      System.out.println("具體策略B的策略方法被訪問!");
  }
}
//環境類
class Context
{
    private Strategy strategy;
    public Strategy getStrategy()
{
        return strategy;
    }
    public void setStrategy(Strategy strategy)
{
        this.strategy=strategy;
    }
    public void algorithm()
{
        strategy.algorithm();
    }
}

 

5  代理模式(Proxy)
淘寶店客服總是會收到非常多的重復問題,例如:有沒有現貨?什么時候發貨?發什么快遞?大量回答重復性的問題太煩了,于是就出現了小蜜機器人,他來幫客服回答那些已知的問題,當碰到小蜜無法解答的問題時,才會轉到人工客服,這里的小蜜機器人就是客服的代理,
代理模式結構
代理模式包含如下角色:
  • Subject: 抽象主題角色

  • Proxy: 代理主題角色

  • RealSubject: 真實主題角色

結構圖:
圖片
時序圖:
優缺點
  • 優點:代理可以協調呼叫方與被呼叫方,降低了系統的耦合度,根據代理型別和場景的不同,可以起到控制安全性、減小系統開銷等作用,

  • 缺點:增加了一層代理處理,增加了系統的復雜度,同時可能會降低系統的相應速度,

試用場景
理論上可以代理任何物件,常見的代理模式有:
  • 遠程(Remote)代理:為一個位于不同的地址空間的物件提供一個本地的代理物件,這個不同的地址空間可以是在同一臺主機中,也可是在另一臺主機中,遠程代理又叫做大使(Ambassador),

  • 虛擬(Virtual)代理:如果需要創建一個資源消耗較大的物件,先創建一個消耗相對較小的物件來表示,真實物件只在需要時才會被真正創建,

  • Copy-on-Write代理:它是虛擬代理的一種,把復制(克隆)操作延遲到只有在客戶端真正需要時才執行,一般來說,物件的深克隆是一個開銷較大的操作,Copy-on-Write代理可以讓這個操作延遲,只有物件被用到的時候才被克隆,

  • 保護(Protect or Access)代理:控制對一個物件的訪問,可以給不同的用戶提供不同級別的使用權限,

  • 緩沖(Cache)代理:為某一個目標操作的結果提供臨時的存盤空間,以便多個客戶端可以共享這些結果,

  • 防火墻(Firewall)代理:保護目標不讓惡意用戶接近,

  • 同步化(Synchronization)代理:使幾個用戶能夠同時使用一個物件而沒有沖突,

  • 智能參考(Smart Reference)代理:當一個物件被參考時,提供一些額外的操作,如將此物件被呼叫的次數記錄下來等,

簡單實作

package proxy;
public class ProxyPattern
{
    public static void main(String[] args)
{
        Proxy proxy = new Proxy();
        proxy.request();
    }
}
//抽象主題
interface Subject
{
    void request();
}
//真實主題
class RealSubject implements Subject
{
    public void request()
{
        System.out.println("訪問真實主題方法...");
    }
}
//代理
class Proxy implements Subject
{
    private RealSubject realSubject;
    public void request()
{
        if (realSubject==null)
        {
            realSubject=new RealSubject();
        }
        preRequest();
        realSubject.request();
        afterRequest();
    }
    public void preRequest()
{
        System.out.println("訪問真實主題之前的預處理,");
    }
    public void afterRequest()
{
        System.out.println("訪問真實主題之后的后續處理,");
    }
}

 

6  觀察者模式(Observer)
出差在外,想了解孩子在家的情況,這時候只要加入“相親相愛一家人”群,老爸老媽會經常把孩子的照片和視頻發到群里,你要做的就是作為一個觀察者,刷一刷群里的資訊就能夠了解一切了,
觀察者模式結構
觀察者模式包含如下角色:
  • Subject:目標

  • ConcreteSubject:具體目標

  • Observer:觀察者

  • ConcreteObserver:具體觀察者

結構圖:
圖片
時序圖:
圖片
優缺點

 

  • 優點:將復雜的串行處理邏輯變為單元化的獨立處理邏輯,被觀察者只是按照自己的邏輯發出訊息,不用關心誰來消費訊息,每個觀察者只處理自己關心的內容,邏輯相互隔離帶來簡單清爽的代碼結構,

  • 缺點:觀察者較多時,可能會花費一定的開銷來發訊息,但這個訊息可能僅一個觀察者消費,

適用場景
適用于一對多的的業務場景,一個物件發生變更,會觸發N個物件做相應處理的場景,例如:訂單調度通知,任務狀態變化等,
注意事項
避免觀察者與被觀察者之間形成回圈依賴,可能會因此導致系統崩潰,
簡單實作

 

package observer;
import java.util.*;
public class ObserverPattern
{
    public static void main(String[] args)
    {
        Subject subject = new ConcreteSubject();
        Observer obsA = new ConcreteObserverA();
        Observer obsb = new ConcreteObserverB();
        subject.add(obsA);
        subject.add(obsB);
        subject.setState(0);
    }
}
//抽象目標
abstract class Subject
{
    protected List<Observer> observerList = new ArrayList<Observer>();   
    //增加觀察者方法
    public void add(Observer observer)
    {
        observers.add(observer);
    }    
    //洗掉觀察者方法
    public void remove(Observer observer)
    {
        observers.remove(observer);
    }   
    public abstract void notify(); //通知觀察者方法
}
//具體目標
class ConcreteSubject extends Subject
{
   private Integer state;
   public void setState(Integer state){
        this.state = state;

        // 狀態改變通知觀察者
        notify();
    }
    public void notify()
    {
        System.out.println("具體目標狀態發生改變...");
        System.out.println("--------------");       

        for(Observer obs:observers)
        {
            obs.process();
        }

    }          
}
//抽象觀察者
interface Observer
{
    void process(); //具體的處理
}
//具體觀察者A
class ConcreteObserverA implements Observer
{
    public void process()
    {
        System.out.println("具體觀察者A處理!");
    }
}
//具體觀察者B
class ConcreteObserverB implements Observer
{
    public void process()
    {
        System.out.println("具體觀察者B處理!");
    }
}

 

作者: 銘劭

本文來自博客園,作者:古道輕風,轉載請注明原文鏈接:https://www.cnblogs.com/88223100/p/How-to-understand-these-six-common-design-patterns.html

轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/542341.html

標籤:設計模式

上一篇:Redis分布式鎖的五大演進攻略

下一篇:如何理解這6種常見設計模式?

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more