成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

工作五年了,居然還不懂門面模式!

開發 前端
門面模式(Facade Pattern)又叫作外觀模式,提供了一個統一的接口,用來訪問子系統中的一群接口。其主要特征是定義了一個高層接口,讓子系統更容易使用,屬于結構型設計模式。

[[403145]]

大家好,我是老田,從今天開始,本公眾號每周給大家送福利,送什么呢?肯定是技術書啦,不搞那么多花里胡哨的,參與方式見文末。

好啦,進入我們的主題,今天我給大家分享設計模式中的門面模式。用貼切的生活故事,以及真實項目場景來講設計模式,最后用一句話來總結這個設計模式。

故事

開發的朋友都知道,后端開發通常都是:

controller---servie---dao/mapper/repository

但是,我問過很多人,熟悉門面模式不?有的工作五年了都不知道。

今天老田,就帶你來看看門面模式。

門面模式概述

門面模式(Facade Pattern)又叫作外觀模式,提供了一個統一的接口,用來訪問子系統中的一群接口。其主要特征是定義了一個高層接口,讓子系統更容易使用,屬于結構型設計模式。

英文:

Provide a unified interface to a set of interfaces in asubsystem.Facade defines a higher-level interface that makes thesubsystem easier to use.

其實,在日常編碼工作中,我們都在有意無意地大量使用門面模式。但凡只要高層模塊需要調度多個子系統(2個以上類對象),我們都會自覺地創建一個新類封裝這些子系統,提供精簡的接口,讓高層模塊可以更加容易地間接調用這些子系統的功能。

生活中的案例

關于門面模式,在生活中的案例,非常之多。

案例1:去銀行辦理業務,有個前臺接待你,然后,這個前臺會問你需要辦什么業務,他會一個一個帶你辦理,這樣我們就不需要到處亂串、到處找對應業務窗口了。這個前臺人員就相當于門面模式。

案例2:我們建房子,如果沒有包工頭的話,那就是你自己要去找水泥工,電工、裝修工等。但如果有了包工頭,這些活你都不用干了,直接跟包工頭說,需要電工來把線路搞好。這個包工頭就可以理解為門面模式。

案例3:我們后端開發的controller,也可以理解為門面模式,比如說獲取用戶賬戶信息,先查UserService獲取用戶信息,然后查UserAccountService用戶賬戶信息。

門面模式適用場景

在軟件系統中,門面模式適用于以下應用場景。

  • 為一個復雜的模塊或子系統提供一個簡潔的供外界訪問的接口。
  • 希望提高子系統的獨立性時。
  • 當子系統由于不可避免的暫時原因導致可能存在Bug或性能相關問題時,可以通過門面模式提供一個高層接口,隔離客戶端與子系統的直接交互,預防代碼污染。

門面模式通用寫法

還是使用代碼來實現一個簡單的門面模式,因為咱們最喜歡的就是從demo開始。

業務場景:現在需要調用三個service的各自的方法:

  1. public class ServiceA { 
  2.     public void doA(){ 
  3.         System.out.println("do ServiceA"); 
  4.     } 
  5. public class ServiceB { 
  6.     public void doB(){ 
  7.         System.out.println("do ServiceB"); 
  8.     } 
  9.  
  10. public class ServiceC { 
  11.     public void doC(){ 
  12.         System.out.println("do ServiceC"); 
  13.     } 

在沒有引入門面模式的時候,客戶端是這么調用的:

  1. public class Client { 
  2.     public static void main(String[] args) { 
  3.         ServiceA serviceA=new ServiceA(); 
  4.         ServiceB serviceB=new ServiceB(); 
  5.         ServiceC serviceC=new ServiceC(); 
  6.  
  7.         serviceA.doA(); 
  8.         serviceB.doB(); 
  9.         serviceC.doC(); 
  10.     } 

每次,客戶端自己都需要創建很多service對象,如果涉及到有很多個service,那這代碼不是很尷尬嗎?會出現大量重復性的代碼。

運行結果

  1. do ServiceA 
  2. do ServiceB 
  3. do ServiceC 

下面我們就來加入門面模式:

  1. public class Facade { 
  2.     //是不是很像我們controller里注入各種service? 
  3.     private ServiceA serviceA = new ServiceA(); 
  4.     private ServiceB serviceB = new ServiceB(); 
  5.     private ServiceC serviceC = new ServiceC(); 
  6.  
  7.     public void doA() { 
  8.         serviceA.doA(); 
  9.     } 
  10.  
  11.     public void doB() { 
  12.         serviceB.doB(); 
  13.     } 
  14.  
  15.     public void doC() { 
  16.         serviceC.doC(); 
  17.     } 

客戶端變成了:

  1. public class Client { 
  2.     public static void main(String[] args) { 
  3.         //輕輕松松的搞定,只需要創建門面這個對象即可 
  4.         Facade facade=new Facade(); 
  5.         facade.doA(); 
  6.         facade.doB(); 
  7.         facade.doC(); 
  8.     } 

運行結果:

  1. do ServiceA 
  2. do ServiceB 
  3. do ServiceC 

門面模式UML圖

結合這個UML圖,在回顧銀行前臺人員和包工頭的案例,就更輕松的理解門面模式了。

門面模式中的角色

由上圖可以看到,門面模式主要包含2個角色。

  • 外觀角色(Facade):也叫作門面角色,是系統對外的統一接口。
  • 子系統角色(Service):可以同時有一個或多個Service。每個Service都不是一個單獨的類,而是一個類的集合。Service們并不知道Facade的存在,對于Service們而言,Facade 只是另一個客戶端而已(即Facade對ServiceA、ServiceB、ServiceC透明)。

門面模式的擴展

優點

● 減少系統的相互依賴   想想看,如果我們不使用門面模式,外界訪問直接深入到子系統內部,相互之間是一種強耦合關系,你死我就死,你活我才能活,這樣的強依賴是系統設計所不能接受的,門面模式的出現就很好地解決了該問題,所有的依賴都是對門面對象的依賴,與子系統無關。

● 提高了靈活性   依賴減少了,靈活性自然提高了。不管子系統內部如何變化,只要不影響到門面對象,任你自由活動。

● 提高安全性   想讓你訪問子系統的哪些業務就開通哪些邏輯,不在門面上開通的方法,你休想訪問到 。

缺點

當增加子系統和擴展子系統行為時,可能容易帶來未知風險。

不符合開閉原則。

某些情況下,可能違背單一職責原則。

大神們是如何使用的

在Spring中也是有大量使用到門面模式,比如說

  1. org.springframework.jdbc.support.JdbcUtils 

再來看看其中的方法

  1. public static void closeConnection(@Nullable Connection con) { 
  2.     con.close(); 
  3. public static Object extractDatabaseMetaData(DataSource dataSource, DatabaseMetaDataCallback action
  4.    throws MetaDataAccessException { 
  5.     Connection con = null
  6.   try { 
  7.    con = DataSourceUtils.getConnection(dataSource); 
  8.    DatabaseMetaData metaData = con.getMetaData(); 
  9.    if (metaData == null) { 
  10.       //..... 
  11.    } 
  12.    return action.processMetaData(metaData); 
  13.   } 
  14. ...... 

都是給我封裝好了方法,對于我們開發者來說,我只面向JdbcUtils這一個類就好了,我不用去管Connection、ResultSet等是怎么創建的,需要的時候,我調用JdbcUtils的對應方法即可獲得對應的對象。

在Mybatis中也是用到了門面模式,比如:

  1. org.apache.ibatis.session.Configuration 

在Configuration中以new開頭的方法,比如:

  1. public Executor newExecutor(Transaction transaction) { 
  2.     return newExecutor(transaction, defaultExecutorType); 
  3. public MetaObject newMetaObject(Object object) { 
  4.     return MetaObject.forObject(object, objectFactory, objectWrapperFactory, reflectorFactory); 
  5.  
  6. public ParameterHandler newParameterHandler(MappedStatement mappedStatement, Object parameterObject, BoundSql boundSql) { 
  7.     ... 
  8.     return parameterHandler; 
  9.  
  10. public ResultSetHandler newResultSetHandler(Executor executor, MappedStatement mappedStatement, RowBounds rowBounds, ParameterHandler parameterHandler, 
  11.       ResultHandler resultHandler, BoundSql boundSql) { 
  12.    ... 
  13.     return resultSetHandler; 
  14.  
  15. public StatementHandler newStatementHandler(Executor executor, MappedStatement mappedStatement){ 
  16.    ... 

對于調用這些方法的地方,他并不知道是怎么new出來的對象,只管使用就行了。

在Tomcat中也有門面模式,比如:

  1. org.apache.catalina.connector.RequestFacade 

從名字就知道它用了門面模式。它封裝了非常多的request操作,也整合了很多servlet-api以外的內容,給用戶使用提供了很大便捷。同樣,Tomcat針對Response和Session也封裝了對應的ResponseFacade類和StandardSessionFacade類,感興趣的小伙伴可以深入了解一下。

PS:基本上所有以Facade結尾的類,都是使用到了門面模式。

參考:tom的設計模式課程

總結

好了,關于門面模式就分享這么多,看完本文是不是覺得門面模式其實很簡單的,另外在工作也可以考慮是不是可以把它用上,同時,面試的時候也可以用來吹吹。

最后用一句話來總結門面模式: 

打開一扇門,走向全世界。

本文轉載自微信公眾號「Java后端技術全棧」,可以通過以下二維碼關注。轉載本文請聯系Java后端技術全棧公眾號。

 

責任編輯:武曉燕 來源: Java后端技術全棧
相關推薦

2021-04-18 21:07:32

門面模式設計

2016-03-17 09:55:52

HDFSHadoop分布式文件系統

2023-05-06 07:51:22

JavaFacade設計模式

2021-03-18 15:33:22

設計模式外觀

2022-02-15 22:45:00

前端設計模式

2024-02-19 13:11:38

門面模式系統

2022-11-14 08:44:56

前端門面模式接口

2021-09-06 07:58:47

鏈表數據結構

2022-05-27 21:56:55

索引存儲MySQL 存儲引擎

2020-02-24 21:50:24

瓶頸數據庫

2019-06-19 09:07:06

HTTP代理協議

2021-06-03 09:18:25

裝飾器模式包裝

2025-06-03 01:43:00

2023-01-02 10:08:42

StampedLocAQS框架

2024-01-05 15:06:04

元素程序員review

2024-08-02 16:31:12

2020-05-20 22:13:26

JVM加載機制虛擬機

2023-05-15 08:02:33

Kafka選舉Broker

2022-01-29 13:59:20

IT專業人員技??術

2022-05-05 10:35:20

IT領域IT領導者
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 色精品视频 | 欧美日韩激情 | 国产伦精品一区二区三区在线 | 日日夜精品视频 | 欧美日韩一区二区三区不卡视频 | 午夜一区二区三区在线观看 | 激情久久av一区av二区av三区 | 久久精品中文字幕 | 欧美成视频 | 视频三区 | 欧美视频二区 | 久久中文字幕av | 男女污污动态图 | 一级国产精品一级国产精品片 | 国产成人精品a视频一区www | 亚洲精品中文字幕 | a精品视频 | 国产美女在线精品免费 | 亚洲91av | 狠狠干天天干 | 久久宗合色 | 欧美黄色一区 | 欧美激情在线播放 | 欧美精品a∨在线观看不卡 国产精品久久国产精品 | av在线一区二区三区 | 日韩不卡一二区 | 久久久久久中文字幕 | 日韩av高清在线 | 一区二区三区欧美在线 | 国产电影一区二区在线观看 | 日韩欧美一区二区三区在线播放 | 亚洲在线日韩 | 日产精品久久久一区二区福利 | 91精品国产欧美一区二区成人 | 精品乱码一区二区三四区视频 | 一区二区三区高清 | 亚洲综合电影 | 午夜一区二区三区视频 | 日韩欧美国产综合 | 久久亚洲精品国产精品紫薇 | 国产精品美女 |