国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - PHP教程 - PHP設計模式(九)外觀模式Facade實例詳解【結構型】

PHP設計模式(九)外觀模式Facade實例詳解【結構型】

2020-06-29 14:06規速 PHP教程

這篇文章主要介紹了PHP設計模式:外觀模式Facade,結合實例形式詳細分析了PHP外觀模式Facade相關概念、功能、原理、用法與操作注意事項,需要的朋友可以參考下

本文實例講述了PHP設計模式外觀模式Facade。分享給大家供大家參考,具體如下:

1. 概述

 

     外觀模式,我們通過外觀的包裝,使應用程序只能看到外觀對象,而不會看到具體的細節對象,這樣無疑會降低應用程序的復雜度,并且提高了程序的可維護性。
例子1:一個電源總開關可以控制四盞燈、一個風扇、一臺空調和一臺電視機的啟動和關閉。該電源總開關可以同時控制上述所有電器設備,電源總開關即為該系統的外觀模式設計。

2. 問題

 

為了降低復雜性,常常將系統劃分為若干個子系統。但是如何做到各個系統之間的通信和相互依賴關系達到最小呢?

3. 解決方案

 

外觀模式:為子系統中的一組接口提供一個一致的界面, Facade模式定義了一個高層接口,這個接口使得這一子系統更加容易使用。引入外觀角色之后,用戶只需要直接與外觀角色交互,用戶與子系統之間的復雜關系由外觀角色來實現,從而降低了系統的耦合度。

PHP設計模式(九)外觀模式Facade實例詳解【結構型】

4. 適用性

 

在遇到以下情況使用facade模式:
    1) 當你要為一個復雜子系統提供一個簡單接口時。子系統往往因為不斷演化而變得越來越復雜。大多數模式使用時都會產生更多更小的類。
    這使得子系統更具可重用性,也更容易對子系統進行定制,但這也給那些不需要定制子系統的用戶帶來一些使用上的困難。facade可以提供一個簡單的缺省視圖,
    這一視圖對大多數用戶來說已經足夠,而那些需要更多的可定制性的用戶可以越過facade層。
    2) 客戶程序與抽象類的實現部分之間存在著很大的依賴性。引入 facade將這個子系統與客戶以及其他的子系統分離,可以提高子系統的獨立性 和可移植性。
    3) 當你需要構建一個層次結構的子系統時,使用 facade模式定義子系統中每層的入口點。如果子系統之間是相互依賴的,你可以讓它們僅通過facade進行通訊,從而簡化了它們之間的依賴關系。

5. 結構

 

PHP設計模式(九)外觀模式Facade實例詳解【結構型】

PHP設計模式(九)外觀模式Facade實例詳解【結構型】

6.構建模式的組成

 

外觀角色(Facade):是模式的核心,他被客戶client角色調用,知道各個子系統的功能。同時根據客戶角色已有的需求預訂了幾種功能組合\
子系統角色(Subsystem classes):實現子系統的功能,并處理由Facade對象指派的任務。對子系統而言,facade和client角色是未知的,沒有Facade的任何相關信息;即沒有指向Facade的實例。
客戶角色(client):調用facade角色獲得完成相應的功能。

7. 效果

 

Facade模式有下面一些優點:

1)對客戶屏蔽子系統組件,減少了客戶處理的對象數目并使得子系統使用起來更加容易。通過引入外觀模式,客戶代碼將變得很簡單,與之關聯的對象也很少。
2)實現了子系統與客戶之間的松耦合關系,這使得子系統的組件變化不會影響到調用它的客戶類,只需要調整外觀類即可。
3)降低了大型軟件系統中的編譯依賴性,并簡化了系統在不同平臺之間的移植過程,因為編譯一個子系統一般不需要編譯所有其他的子系統。一個子系統的修改對其他子系統沒有任何影響,而且子系統內部變化也不會影響到外觀對象。
4)只是提供了一個訪問子系統的統一入口,并不影響用戶直接使用子系統類。
Facade模式的缺點
1) 不能很好地限制客戶使用子系統類,如果對客戶訪問子系統類做太多的限制則減少了可變性和靈活性。
2) 在不引入抽象外觀類的情況下,增加新的子系統可能需要修改外觀類或客戶端的源代碼,違背了“開閉原則”。

8. 實現

 

我們使用開關的例子;

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
<?php
/**
 * 外觀模式
 *
 */
 class SwitchFacade
{
    private $_light     = null;     //電燈
    private $_ac        = null;     //空調
    private $_fan       = null;     //電扇
    private $_tv        = null;     //電視
    
    public function __construct()
    {
        $this->_light = new Light();
        $this->_fan = new Fan();
        $this->_ac = new AirConditioner();
        $this->_tv = new Television();
    }
    /**
     * 晚上開電燈
     *
     */
    public function method1($isOpen =1) {
        if ($isOpen == 1) {
            $this->_light->on();
            $this->_fan->on();
            $this->_ac->on();
            $this->_tv->on();
        }else{
            $this->_light->off();
            $this->_fan->off();
            $this->_ac->off();
            $this->_tv->off();
        }
 
    }
    /**
     * 白天不需要電燈
     *
     */
    public function method2() {
        if ($isOpen == 1) {
            $this->_fan->on();
            $this->_ac->on();
            $this->_tv->on();
        }else{
            $this->_fan->off();
            $this->_ac->off();
            $this->_tv->off();
        }
    }
}
 
/******************************************子系統類 ************/
/**
 *
*/
class Light
{  
    private $_isOpen = 0;
    public function on() {
        echo 'Light is open', '<br/>';
        $this->_isOpen = 1;
    }
    public function off() {
        echo 'Light is off', '<br/>';
        $this->_isOpen = 0;
    }
}
 
class Fan
{
    private $_isOpen = 0;
    public function on() {
        echo 'Fan is open', '<br/>';
        $this->_isOpen = 1;
    }
    public function off() {
        echo 'Fan is off', '<br/>';
        $this->_isOpen = 0;
    }
}
 
class AirConditioner
{
    private $_isOpen = 0;
    public function on() {
        echo 'AirConditioner is open', '<br/>';
        $this->_isOpen = 1;
    }
    public function off() {
        echo 'AirConditioner is off', '<br/>';
        $this->_isOpen = 0;
    }
}
class Television
{
    private $_isOpen = 0;
    public function on() {
        echo 'Television is open', '<br/>';
        $this->_isOpen = 1;
    }
    public function off() {
        echo 'Television is off', '<br/>';
        $this->_isOpen = 0;
    }
}
/**
 * 客戶類
 *
 */
class client {
    static function open() {
        $f = new SwitchFacade();
        $f->method1(1);
    }
 
    static function close() {
        $f = new SwitchFacade();
        $f->method1(0);
    }
}
client::open();

11. 與其他相關模式

 

    1)抽象工廠模式:Abstract Factory式可以與Facade模式一起使用以提供一個接口,這一接口可用來以一種子系統獨立的方式創建子系統對象。 Abstract Factory也可以代替Facade模式隱藏那些與平臺相關的類。
    2)中介模式:Mediator模式與Facade模式的相似之處是,它抽象了一些已有的類的功能。然而,Mediator的目的是對同事之間的任意通訊進行抽象,通常集中不屬于任何單個對象的功能。
    Mediator的同事對象知道中介者并與它通信,而不是直接與其他同類對象通信。相對而言,Facade模式僅對子系統對象的接口進行抽象,從而使它們更容易使用;它并不定義新功能,子系統也不知道Facade的存在。
    通常來講,僅需要一個Facade對象,因此Facade對象通常屬于Singleton模式。
    3)Adapter模式
    適配器模式是將一個接口通過適配來間接轉換為另一個接口。
    外觀模式的話,其主要是提供一個整潔的一致的接口給客戶端。

12. 總結

 

1)根據“單一職責原則”,在軟件中將一個系統劃分為若干個子系統有利于降低整個系統的復雜性,一個常見的設計目標是使子系統間的通信和相互依賴關系達到最小,而達到該目標的途徑之一就是引入一個外觀對象,它為子系統的訪問提供了一個簡單而單一的入口。

2)外觀模式也是“迪米特法則”的體現通過引入一個新的外觀類可以降低原有系統的復雜度,外觀類充當了客戶類與子系統類之間的“第三者”,同時降低客戶類與子系統類的耦合度。外觀模式就是實現代碼重構以便達到“迪米特法則”要求的一個強有力的武器。

3)外觀模式要求一個子系統的外部與其內部的通信通過一個統一的外觀對象進行,外觀類將客戶端與子系統的內部復雜性分隔開,使得客戶端只需要與外觀對象打交道,而不需要與子系統內部的很多對象打交道。 4)外觀模式從很大程度上提高了客戶端使用的便捷性,使得客戶端無須關心子系統的工作細節,通過外觀角色即可調用相關功能。 5)不要試圖通過外觀類為子系統增加新行為 ,不要通過繼承一個外觀類在子系統中加入新的行為,這種做法是錯誤的。外觀模式的用意是為子系統提供一個集中化和簡化的溝通渠道,而不是向子系統加入新的行為,新的行為的增加應該通過修改原有子系統類或增加新的子系統類來實現,不能通過外觀類來實現。

13.模式擴展

 

一個系統有多個外觀類:
         在外觀模式中,通常只需要一個外觀類,并且此外觀類只有一個實例,換言之它是一個單例類在很多情況下為了節約系統資源,一般將外觀類設計為單例類。當然這并不意味著在整個系統里只能有一個外觀類,在一個系統中可以設計多個外觀類,每個外觀類都負責和一些特定的子系統交互,向用戶提供相應的業務功能。
不要試圖通過外觀類為子系統增加新行為:
        不要通過繼承一個外觀類在子系統中加入新的行為,這種做法是錯誤的。外觀模式的用意是為子系統提供一個集中化和簡化的溝通渠道,而不是向子系統加入新的行為,新的行為的增加應該通過修改原有子系統類或增加新的子系統類來實現,不能通過外觀類來實現。
外觀模式與迪米特法則:
        外觀模式創造出一個外觀對象,將客戶端所涉及的屬于一個子系統的協作伙伴的數量減到最少,使得客戶端與子系統內部的對象的相互作用被外觀對象所取代。外觀類充當了客戶類與子系統類之間的“第三者”,降低了客戶類與子系統類之間的耦合度,外觀模式就是實現代碼重構以便達到“迪米特法則”要求的一個強有力的武器。
抽象外觀類的引入:
外觀模式最大的缺點在于違背了“開閉原則”,當增加新的子系統或者移除子系統時需要修改外觀類,可以通過引入抽象外觀類在一定程度上解決該問題,客戶端針對抽象外觀類進行編程。對于新的業務需求,不修改原有外觀類,而對應增加一個新的具體外觀類,由新的具體外觀類來關聯新的子系統對象,同時通過修改配置文件來達到不修改源代碼并更換外觀類的目的。 

UML:

PHP設計模式(九)外觀模式Facade實例詳解【結構型】

 

希望本文所述對大家PHP程序設計有所幫助。

原文鏈接:https://blog.csdn.net/hguisu/article/details/7533759

延伸 · 閱讀

精彩推薦
Weibo Article 1 Weibo Article 2 Weibo Article 3 Weibo Article 4 Weibo Article 5 Weibo Article 6 Weibo Article 7 Weibo Article 8 Weibo Article 9 Weibo Article 10 Weibo Article 11 Weibo Article 12 Weibo Article 13 Weibo Article 14 Weibo Article 15 Weibo Article 16 Weibo Article 17 Weibo Article 18 Weibo Article 19 Weibo Article 20 Weibo Article 21 Weibo Article 22 Weibo Article 23 Weibo Article 24 Weibo Article 25 Weibo Article 26 Weibo Article 27 Weibo Article 28 Weibo Article 29 Weibo Article 30 Weibo Article 31 Weibo Article 32 Weibo Article 33 Weibo Article 34 Weibo Article 35 Weibo Article 36 Weibo Article 37 Weibo Article 38 Weibo Article 39 Weibo Article 40
主站蜘蛛池模板: 亚洲日本乱码一区两区在线观看 | 久久国产高清 | 欧美久久久久 | 欧美一区二区免费在线观看 | 在线精品亚洲欧美日韩国产 | 免费精品视频一区二区三区 | 成人欧美一区二区三区白人 | 91麻豆精品国产91久久久久久久久 | 午夜视频网 | 欧美久久综合 | 亚洲视频天堂 | 亚洲视频免费观看 | 日韩在线视频观看免费 | 男女免费观看在线爽爽爽视频 | 青青草中文字幕 | 欧美日韩专区 | 久久久久久九九 | 福利在线看 | 欧美国产精品一区 | 免费观看的av | 久久久久久国产精品 | 在线观看一区三区 | 农村末发育av片四区五区 | 人人爱人人爽 | 日本在线视频免费观看 | 欧美黄色精品 | 中文字幕在线观看一区二区三区 | 成人一区二区三区久久精品嫩草 | 日韩视频中文字幕 | 久久久人成影片免费观看 | 国语精品久久 | 波多野结衣一二三四区 | 97人人爱 | 亚洲成人一区二区 | 久久久成人精品 | 一区二区不卡视频 | 欧美一区二区三区精品 | 国产精品成人一区二区 | 在线观看黄色 | 亚洲乱码国产乱码精品精98午夜 | 国产精品一区二 |