摘要:適配器是將接口轉(zhuǎn)換為不同接口,而外觀模式是提供一個(gè)統(tǒng)一的接口來簡化接口。
概述外觀模式(Facade Pattern)屬于結(jié)構(gòu)型模式的一種,為子系統(tǒng)中的一組接口提供一個(gè)統(tǒng)一的入口,它通過引入一個(gè)外觀角色來簡化客戶端與子系統(tǒng)之間的交互...
外觀模式是一種使用頻率非常高的結(jié)構(gòu)型設(shè)計(jì)模式,當(dāng)你要為一個(gè)復(fù)雜子系統(tǒng)提供一個(gè)簡單接口時(shí)。子系統(tǒng)往往因?yàn)椴粩嘌莼兊迷絹碓綇?fù)雜。大多數(shù)模式使用時(shí)都會(huì)產(chǎn)生更多更小的類。這使得子系統(tǒng)更具可重用性,也更容易對(duì)子系統(tǒng)進(jìn)行定制,但這也給那些不需要定制子系統(tǒng)的用戶帶來一些使用上的困難。Facade可以提供一個(gè)簡單的缺省視圖,這一視圖對(duì)大多數(shù)用戶來說已經(jīng)足夠,而那些需要更多的可定制性的用戶可以越過Facade層
如下圖:
案例購物場景中,我們要調(diào)用產(chǎn)品(Product)和支付(Pay)等服務(wù),這時(shí)候面對(duì)了多個(gè)復(fù)雜的業(yè)務(wù),怎么樣通過模式來解決?
創(chuàng)建ProductService 和 PayService
class ProductService { public void pick() { System.out.println("挑選小米Mix2尊享版"); } } class PayService { public void pay() { System.out.println("支付4799元"); } }
定義外觀類FacadeOrder由它統(tǒng)一調(diào)用,客戶端無需關(guān)心具體實(shí)現(xiàn)
class FacadeOrder { private ProductService productService; private PayService payService; public FacadeOrder() { this.productService = new ProductService(); this.payService = new PayService(); } public void buyPhone() { this.productService.pick(); System.out.println("添加購物車"); this.payService.pay(); } }
創(chuàng)建測試類Client
public class Client { public static void main(String[] args) { FacadeOrder order = new FacadeOrder(); order.buyPhone(); } }
運(yùn)行結(jié)果
挑選小米Mix2尊享版 添加購物車 支付4799元總結(jié)
細(xì)心的朋友會(huì)發(fā)現(xiàn),該模式應(yīng)用其實(shí)非常之廣泛,與我們平時(shí)寫的DAO->Service->Controller是不是很相像呢
優(yōu)點(diǎn)
降低了客戶類與子系統(tǒng)類的耦合度,實(shí)現(xiàn)了子系統(tǒng)與客戶之間的松耦合關(guān)系
外觀模式對(duì)客戶屏蔽了子系統(tǒng)組件,從而簡化了接口,減少了客戶處理的對(duì)象數(shù)目并使子系統(tǒng)的使用更加簡單。
客戶程序與抽象類的實(shí)現(xiàn)部分之間存在著很大的依賴性,引入Facade將這個(gè)子系統(tǒng)與客戶以及其他的子系統(tǒng)分離,可以提高子系統(tǒng)的獨(dú)立性和可移植性。
缺點(diǎn)
在不引入抽象外觀類的情況下,增加新的子系統(tǒng)可能需要修改外觀類或客戶端的源代碼,違背了開閉原則
與適配器模式的區(qū)別
適配器模式是將一個(gè)對(duì)象包裝起來以改變其接口,而外觀模式是將一群對(duì)象包裝起來以簡化其接口。適配器是將接口轉(zhuǎn)換為不同接口,而外觀模式是提供一個(gè)統(tǒng)一的接口來簡化接口。
- 說點(diǎn)什么全文代碼:https://gitee.com/battcn/design-pattern/tree/master/Chapter8/battcn-facade
個(gè)人QQ:1837307557
battcn開源群(適合新手):391619659
微信公眾號(hào):battcn(歡迎調(diào)戲)
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://specialneedsforspecialkids.com/yun/68006.html
摘要:本文來自原文鏈接歡迎作客我們的學(xué)習(xí)群該篇屬于底層核心技術(shù)實(shí)戰(zhàn)揭秘這一課程底層核心概念解析這一章的擴(kuò)展閱讀。考慮到學(xué)員們的基礎(chǔ)差異,為了避免視頻當(dāng)中過于詳細(xì)而連篇累牘,故將一些底層實(shí)現(xiàn)相關(guān)的知識(shí)點(diǎn)以文章形式呈現(xiàn),供大家預(yù)習(xí)和隨時(shí)查閱。 本文來自pilishen.com----原文鏈接; 歡迎作客我們的php&Laravel學(xué)習(xí)群:109256050該篇屬于《Laravel底層核心技術(shù)實(shí)戰(zhàn)...
摘要:進(jìn)階多線程開發(fā)關(guān)鍵技術(shù)后端掘金原創(chuàng)文章,轉(zhuǎn)載請(qǐng)務(wù)必將下面這段話置于文章開頭處保留超鏈接。關(guān)于中間件入門教程后端掘金前言中間件 Java 開發(fā)人員最常犯的 10 個(gè)錯(cuò)誤 - 后端 - 掘金一 、把數(shù)組轉(zhuǎn)成ArrayList 為了將數(shù)組轉(zhuǎn)換為ArrayList,開發(fā)者經(jīng)常... Java 9 中的 9 個(gè)新特性 - 后端 - 掘金Java 8 發(fā)布三年多之后,即將快到2017年7月下一個(gè)版...
摘要:用專業(yè)的話來講設(shè)計(jì)模式是一套被反復(fù)使用多數(shù)人知曉的經(jīng)過分類編目的代碼設(shè)計(jì)經(jīng)驗(yàn)的總結(jié)創(chuàng)建型模式,共五種工廠方法模式抽象工廠模式單例模式建造者模式原型模式。工廠方法模式的擴(kuò)展性非常優(yōu)秀。工廠方法模式是典型的解耦框架。 前言 最近一直在Java方向奮斗《終于,我還是下決心學(xué)Java后臺(tái)了》,今天抽空開始學(xué)習(xí)Java的設(shè)計(jì)模式了。計(jì)劃有時(shí)間就去學(xué)習(xí),你這么有時(shí)間,還不來一起上車嗎? 之所以要學(xué)...
閱讀 3425·2021-11-15 11:39
閱讀 1565·2021-09-22 10:02
閱讀 1313·2021-08-27 16:24
閱讀 3601·2019-08-30 15:52
閱讀 3415·2019-08-29 16:20
閱讀 828·2019-08-28 18:12
閱讀 553·2019-08-26 18:27
閱讀 722·2019-08-26 13:32