• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            C++ Programmer's Cookbook

            {C++ 基礎} {C++ 高級} {C#界面,C++核心算法} {設計模式} {C#基礎}

            設計模式概念

            在面向對象的編程中,軟件編程人員更加注重以前的代碼的重用性和可維護性。

            設計模式使人們可以更加簡單方便地復用成功的設計和體系結構。將已證實的技術表述成設計模式也會使新系統開發者更加容易理解其設計思路。

            一般而言,一個模式有四個基本要素

            1. 模式名稱(pattern name) 一個助記名,
            2. 問題(problem) 描述了應該在何時使用模式。它解釋了設計問題和問題存在的前因后果,它可能描述了特定的設計問題,如怎樣用對象表示算法等。也可能描述了導致不靈活設計的類或對象結構。有時候,問題部分會包括使用模式必須滿足的一系列先決條件。

            3. 解決方案(solution) 描述了設計的組成成分,它們之間的相互關系及各自的職責和協作方式。因為模式就像一個模板,可應用于多種不同場合,所以解決方案并不描述一個特定而具體的設計或實現,而是提供設計問題的抽象描述和怎樣用一個具有一般意義的元素組合(類或對象組合)來解決這個問題。

            4. 效果(consequences) 描述了模式應用的效果及使用模式應權衡的問題。盡管我們描述設計決策時,并不總提到模式效果,但它們對于評價設計選擇和理解使用模式的代價及好處具有重要意義。軟件效果大多關注對時間和空間的衡量,它們也表述了語言和實現問題。因為復用是面向對象設計的要素之一,所以模式效果包括它對系統的靈活性、擴充性或可移植性的影響,顯式地列出這些效果對理解和評價這些模式很有幫助。

            一些基本的設計模式

            Abstract Factory:提供一個創建一系列相關或相互依賴對象的接口,而無需指定它們具體的類。

            Adapter:將一個類的接口轉換成客戶希望的另外一個接口。A d a p t e r模式使得原本由于接口不兼容而不能一起工作的那些類可以一起工作。

            Bridge:將抽象部分與它的實現部分分離,使它們都可以獨立地變化。

            Builder:將一個復雜對象的構建與它的表示分離,使得同樣的構建過程可以創建不同的表示。

            Chain of Responsibility:為解除請求的發送者和接收者之間耦合,而使多個對象都有機會處理這個請求。將這些對象連成一條鏈,并沿著這條鏈傳遞該請求,直到有一個對象處理它。

            Command:將一個請求封裝為一個對象,從而使你可用不同的請求對客戶進行參數化;對請求排隊或記錄請求日志,以及支持可取消的操作。

            Composite:將對象組合成樹形結構以表示“部分-整體”的層次結構。它使得客戶對單個對象和復合對象的使用具有一致性。

            Decorator:動態地給一個對象添加一些額外的職責。就擴展功能而言, 它比生成子類方式更為靈活。

            Facade:為子系統中的一組接口提供一個一致的界面, F a c a d e模式定義了一個高層接口,這個接口使得這一子系統更加容易使用。

            Factory Method:定義一個用于創建對象的接口,讓子類決定將哪一個類實例化。Factory Method使一個類的實例化延遲到其子類。

            Flyweight:運用共享技術有效地支持大量細粒度的對象。

            Interpreter:給定一個語言, 定義它的文法的一種表示,并定義一個解釋器, 該解釋器使用該表示來解釋語言中的句子。

            Iterator:提供一種方法順序訪問一個聚合對象中各個元素, 而又不需暴露該對象的內部表示。

            Mediator:用一個中介對象來封裝一系列的對象交互。中介者使各對象不需要顯式地相互引用,從而使其耦合松散,而且可以獨立地改變它們之間的交互。

            Memento:在不破壞封裝性的前提下,捕獲一個對象的內部狀態,并在該對象之外保存這個狀態。這樣以后就可將該對象恢復到保存的狀態。

            Observer:定義對象間的一種一對多的依賴關系,以便當一個對象的狀態發生改變時,所有依賴于它的對象都得到通知并自動刷新。

            Prototype:用原型實例指定創建對象的種類,并且通過拷貝這個原型來創建新的對象。

            Proxy:為其他對象提供一個代理以控制對這個對象的訪問。

            Singleton:保證一個類僅有一個實例,并提供一個訪問它的全局訪問點。

            State:允許一個對象在其內部狀態改變時改變它的行為。對象看起來似乎修改了它所屬的類。

            Strategy:定義一系列的算法,把它們一個個封裝起來, 并且使它們可相互替換。本模式使得算法的變化可獨立于使用它的客戶。

            Template Method:定義一個操作中的算法的骨架,而將一些步驟延遲到子類中。Template Method使得子類可以不改變一個算法的結構即可重定義該算法的某些特定步驟。

            Visitor:表示一個作用于某對象結構中的各元素的操作。它使你可以在不改變各元素的類的前提下定義作用于這些元素的新操作。

            posted on 2005-12-30 14:44 夢在天涯 閱讀(3197) 評論(1)  編輯 收藏 引用 所屬分類: Design pattern

            評論

            # re: 設計模式概念 2008-05-06 09:09 思迷思

            很好,很清析,收轉學習,謝謝。  回復  更多評論   

            公告

            EMail:itech001#126.com

            導航

            統計

            • 隨筆 - 461
            • 文章 - 4
            • 評論 - 746
            • 引用 - 0

            常用鏈接

            隨筆分類

            隨筆檔案

            收藏夾

            Blogs

            c#(csharp)

            C++(cpp)

            Enlish

            Forums(bbs)

            My self

            Often go

            Useful Webs

            Xml/Uml/html

            搜索

            •  

            積分與排名

            • 積分 - 1804303
            • 排名 - 5

            最新評論

            閱讀排行榜

            国产午夜电影久久| 亚洲国产精品久久久天堂 | 国产精品对白刺激久久久| 国产精品一区二区久久| 欧美与黑人午夜性猛交久久久| 亚洲国产高清精品线久久| 日韩精品无码久久久久久| 久久国产成人| 国产国产成人精品久久| 久久精品卫校国产小美女| 久久精品国产只有精品2020| 香蕉久久夜色精品国产尤物| 国产成人久久AV免费| 国产欧美久久久精品影院| 日韩亚洲欧美久久久www综合网| 武侠古典久久婷婷狼人伊人| 99久久久精品| 无码人妻久久一区二区三区| 久久无码精品一区二区三区| 国产精品视频久久久| 久久久久久久97| 国产成人无码精品久久久性色| 久久人人爽人人爽人人片AV麻豆 | 国产2021久久精品| 久久精品99久久香蕉国产色戒 | 日本精品久久久久久久久免费| 亚洲一本综合久久| 狠狠色丁香婷婷综合久久来| 亚洲综合精品香蕉久久网| 99久久精品免费看国产一区二区三区| 亚洲综合久久综合激情久久| 国产精品99久久久久久人| 人妻精品久久久久中文字幕一冢本| 青青草原综合久久大伊人| 少妇人妻综合久久中文字幕| 一级做a爰片久久毛片毛片| 三级片免费观看久久| 国产一区二区久久久| 久久无码国产专区精品| 伊人久久久AV老熟妇色| 久久久久久国产精品无码超碰|