跳到主要內容

模式總結

設計模式

  • 建立型模式
  • 結構型模式
  • 行為型模式

建立型模式

隱藏了這些類別的實體是如何被建立和放在一起,整個系統關於這些物件所知道的,是由抽象類別所定義的介面。這樣,建立型模式在建立了什麼、誰建立它、它是怎麼被建立的,以及何時建立這些方面提供了很大的靈活性。

鬆耦合

這個問題首先要談談內聚性與耦合性。內聚性描述的是一個常式內部組成部分之間相互聯繫的緊密程度。而耦合性描述的是一個常式與其他常式之間聯繫的緊密程度。軟體開發的目標應該是建立這樣的常式:內部完整,也就柿糕內聚,而與其他常式之間的聯繫則是小巧、直接、可見、靈活的,這就是鬆耦合。

抽象工廠 Abstract Factory

提供一個建立一系列或相關依賴物件的介面,而而無須指定它們具體的類別。

建造者 Builder

將一個複雜物件的構件與它的表示分離,使得同樣的構建過程可以建立不同的表示。

工廠方法 Factory Method

定義一個用於建立物件的介面,讓子類別決定實體化哪一個類別,工廠模式使一個類別的實體化延遲到期子類別。

原型

用原型實體指定建立物件的種類,並且透過拷貝這些原型建立新的物件。

獨體 Singleton

保證一個類別僅有一個實體,並提供一個存取它的全域存取點。

結構型模式

轉接器 Adapter

將一個類別的介面轉換客戶希望的另外一個介面。轉接器模式使得原本由於介面不相容,而不能一起工作的那些類別可以一起工作。

橋接 Bridge

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

組合 Composite

將物件組合成樹形結構已表示「部份-整體」的層次結構,組合模式使得用戶對單個物件和組合物件的使用具有一致性。

裝飾 Decorator

動態給一個物件添加一些額外的職責。就增加功能來說,裝飾模式比產生子類別更加靈活。

外觀 Facade

為子系統中的一組介面提供一個一致的介面,外觀模式定義了一個高層介面,這個介面使得這一子系統更加容易使用。

享元 Flyweight

運用共用技術有效地支援大量細粒度的物件。

代理 Proxy

為其他物件提供一種代理以控制對這個物件的存取。

行為型模式

觀察者 Observer

定義物件間的一種一對多的依賴關係,當一個物件的狀態發生改變時,所有依賴於它的物件都得到通知並被自動更新。

範本方法 Template Method

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

命令 Command

將一個請求封裝為一個物件,從而使你可用不同的請求對客戶進行參數化;可以對請求排隊或紀錄請求日誌,以及支援可取消的操作。

狀態 State

允許一個物件在其內部狀態改變時改變它的行為,讓物件看起來似乎修改了它的類別。

職責鏈 Chain of Responsibility

使多個物件都有機會處理請求,從而避免請求的發送者和接收者之間的耦合關係。將這些物件連成一條鏈,並沿著這條鏈傳遞該請求,直到有一個物件處理它為止。

解譯器 Interpreter

定一個語言,定義它的文法的一種表示,並定義一個解譯器,這個解譯器使用該表示來解釋語言中的句子。

仲介者 Mediator

用一個仲介物件來封裝一系列的物件互動。仲介者使各物件不需要顯式地相互參考,從而使其耦合鬆散,而且可以獨立地改變它們之間的互動。

訪問者 Visitor

表示一個作用於某物件結構中的各的操作。它使你可以在不改變各元素的類別的前提下定義作用於這些元素的新操作。

策略 Strategy

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

備忘錄 Memento

在不破壞封裝性的前提下,捕獲一個物件的內部狀態,並在該物件之外保存這個狀態。這樣以後就可將該物件恢復到原先保存的狀態。

迭代器 Iterator

提供一種方法依序存取一個聚合物件中各個元素,而又不需暴露該物件的內部表示。

留言

這個網誌中的熱門文章

用 C# 批次控制 Word 合併列印

前由 我有全區的電話資料,問題在於我要依不同里別來製作出電話簿。結果如下圖: 單純採用合併列印無法達成我的需求。解決方法係用「功能變數」儲存上一個里別,與現在里別進行比較:若不同,則換頁。不過,這樣功能變數還蠻長的。最後,我還是採用 C# 來解決。 解決方案 用 C# 控制 WORD 中合併列印的「資料來源 Data Source」,給予不同里別的「sqlstatement」。迴圈處理不同的里別即可。但可預見其處理過程會很慢,不過還好,我可以不用在意它,有跑出結果即可。 程式碼 IList<string> areas = new List<string>() { "後壁", "侯伯", "嘉苳", "土溝", "嘉田", "嘉民", "菁豊", "崁頂", "後廍", "墨林", "菁寮", "新嘉", "頂長", "平安", "仕安", "竹新", "新東", "長安", "頂安", "福安", "烏樹" }; string root = @"D:\"; // 根目錄 string data = root + @"\data.docm"; // 資料檔(即資料來源) string template = root + @"\template.docx"; // 已設定好格式與合併欄位的 Word 檔 string output = @"d:\Final"; // 輸出之資料夾 object oMissing = System.Reflection.Missing.Va...

VLC c# 順利編譯

原文網址: http://www.cnblogs.com/haibindev/archive/2011/12/21/2296173.html 原文作者: haibindev 原文標題:c#万能视频播放器 本文的重點在於修正 class VlcPlayer,使其能順利在 VC# Express 2010 .Net Framework 4 下順利編譯。 修正重點在於 CallingConvention = CallingConvention. StdCall 改成 CallingConvention = CallingConvention. Cdecl using System; using System.Runtime.InteropServices; using System.Security; using System.Text; namespace VlcDotNet { class VlcPlayer { private IntPtr libvlc_instance_; private IntPtr libvlc_media_player_; private double duration_; public VlcPlayer(string pluginPath) { string plugin_arg = "--plugin-path=" + pluginPath; string[] arguments = { "-I", "dummy", "--ignore-config", "--no-video-title", plugin_arg }; libvlc_instance_ = LibVlcAPI.libvlc_new(arguments); libvlc_media_player_ = LibVlcAPI.libvlc_media_player_new(libvlc_instance_); } public ...

[轉貼]MySQL 交易功能 Transaction 整理 (XYZ的筆記本)

全文轉貼自: http://xyz.cinc.biz/2013/05/mysql-transaction.html   (XYZ的筆記本) ---------------------------------------------------------------------------------------------------------- 資料庫的交易(Transaction)功能,能確保多個 SQL 指令,全部執行成功,或全部不執行,不會因為一些意外狀況,而只執行一部份指令,造成資料異常。 MySQL 常用的兩個資料表類型:MyISAM、InnoDB, MyISAM  不支援交易功能,所以以下的整理,均是針對 InnoDB  而言。 交易功能4個特性 (ACID)  Atomicity (原子性、不可分割):交易內的 SQL 指令,不管在任何情況,都只能是全部執行完成,或全部不執行。若是發生無法全部執行完成的狀況,則會回滾(rollback)到完全沒執行時的狀態。 Consistency (一致性):交易完成後,必須維持資料的完整性。所有資料必須符合預設的驗證規則、外鍵限制...等。 Isolation (隔離性):多個交易可以獨立、同時執行,不會互相干擾。這一點跟後面會提到的「隔離層級」有關。 Durability (持久性):交易完成後,異動結果須完整的保留。 開始進入交易模式 SQL 指令: START TRANSACTION  或  BEGIN 結束交易模式 交易完成:使用  COMMIT  儲存所有變動,並結束交易。 交易過程異常:使用  ROLLBACK  回滾,取消交易,還原到未進行交易的狀態。(若交易過程連線中斷,沒 COMMIT 提交的變更,亦會如同執行 ROLLBACK 取消交易) 儲存點 (SAVEPOINT) 交易過程中,可標示多個不同的儲存點,有需要時可 ROLLBACK 到某個儲存點。 建立儲存點: SAVEPOINT 名稱 刪除儲存點: RELEASE SAVEPOINT 名稱 ROLLBACK 到某個儲存點: ROLLBACK TO SAVEPOINT 名稱 如...