這三者之間的區別在於三種不同的模式存在於它們各自的抽象層次和具體層次上。架構模式是一個系統的高層次策略,涉及到大尺度的組件以及整體性質和力學。架構模式的好壞可以影響到總體佈局和框架性結構。設計模式是中等尺度的結構策略。這些中等尺度的結構實現了一些大尺度組件的行爲和它們之間的關係。模式的好壞不會影響到系統的總體佈局和總體框架。設計模式定義出子系統或組件的微觀結構。代碼模式(或成例)是特定的範例和與特定語言有關的編程技巧。代碼模式的好壞會影響到一箇中等尺度組件的內部、外部的結構或行爲的底層細節,但不會影響到一個部件或子系統的中等尺度的結構,更不會影響到系統的總體佈局和大尺度框架。
代碼模式或成例(Coding Pattern 或 Idiom)
代碼模式(或成例)是較低層次的模式,並與編程語言密切相關。代碼模式描述怎樣利用一個特定的編程語言的特點來實現一個組件的某些特定的方面或關係。
較爲著名的代碼模式的例子包括雙檢鎖(Double-Check Locking)模式等。
設計模式(Design Pattern)
一個設計模式提供一種提煉子系統或軟件系統中的組件的,或者它們之間的關係的綱要設計。設計模式描述普遍存在的在相互通訊的組件中重複出現的結構,這種結構解決在一定的背景中的具有一般性的設計問題。
設計模式常常劃分成不同的種類,常見的種類有:
創建型設計模式,如工廠方法(Factory Method)模式、抽象工廠(Abstract Factory)模式、原型(Prototype)模式、單例(Singleton)模式,建造(Builder)模式等
結構型設計模式,如合成(Composite)模式、裝飾(Decorator)模式、代理(Proxy)模式、享元(Flyweight)模式、門面(Facade)模式、橋樑(Bridge)模式等
行爲型模式,如模版方法(Template Method)模式、觀察者(Observer)模式、迭代子(Iterator)模式、責任鏈(Chain of Responsibility)模式、備忘錄(Memento)模式、命令(Command)模式、狀態(State)模式、訪問者(Visitor)模式等等。
以上是三種經典類型,實際上還有很多其他的類型,比如Fundamental型、Partition型,Relation型等等
設計模式在特定的編程語言中實現的時候,常常會用到代碼模式。比如單例(Singleton)模式的實現常常涉及到雙檢鎖(Double-Check Locking)模式等。
架構模式(Architectural Pattern)
一個架構模式描述軟件系統裏的基本的結構組織或綱要。架構模式提供一些事先定義好的子系統,指定它們的責任,並給出把它們組織在一起的法則和指南。有些作者把這種架構模式叫做系統模式[STELTING02]。
一個架構模式常常可以分解成很多個設計模式的聯合使用。顯然,MVC模式就是屬於這一種模式。MVC模式常常包括調停者(Mediator)模式、策略(Strategy)模式、合成(Composite)模式、觀察者(Observer)模式等。
此外,常見的架構模式還有:
·Layers(分層)模式,有時也稱Tiers模式
·Blackboard(黑板)模式
·Broker(中介)模式
·Distributed Process(分散過程)模式
·Microkernel(微核)模式
架構模式常常劃分成如下的幾種:
一、 From Mud to Structure型。幫助架構師將系統合理劃分,避免形成一個對象的海洋(A sea of objects)。包括Layers(分層)模式、Blackboard(黑板)模式、Pipes/Filters(管道/過濾器)模式等。
二、分散系統(Distributed Systems)型。爲分散式系統提供完整的架構設計,包括像Broker(中介)模式等。
三、人機互動(Interactive Systems)型,支持包含有人機互動介面的系統的架構設計,例子包括MVC(Model-View-Controller)模式、PAC(Presentation-Abstraction-Control)模式等。
四、Adaptable Systems型,支持應用系統適應技術的變化、軟件功能需求的變化。如Reflection(反射)模式、Microkernel(微核)模式等。
<script type="text/javascript"> var ad_cid; if (window.location.search.substring(1) != "") { ad_cid = window.location.search.substring(1); } else { ad_cid = 412; } </script> <script language="JavaScript" type="text/javascript"> document.getElementById("ad1").innerHTML=document.getElementById("span_ad1").innerHTML; document.getElementById("span_ad1").innerHTML=""; </script> <script type="text/javascript"> if(document.getElementById("contentAdv")) { document.getElementById("contentAdv").innerHTML=document.getElementById("span_ad3").innerHTML; document.getElementById("span_ad3").innerHTML=""; } else { document.getElementById("ad3").innerHTML=document.getElementById("span_ad3").innerHTML; document.getElementById("span_ad3").innerHTML=""; }</script> <script language="JavaScript" type="text/javascript"> document.getElementById("ad2").innerHTML=document.getElementById("span_ad2").innerHTML; document.getElementById("span_ad2").innerHTML=""; </script> <script language="JavaScript" type="text/javascript"> document.getElementById("ad10").innerHTML=document.getElementById("span_ad10").innerHTML; document.getElementById("span_ad10").innerHTML=""; </script> <script language="JavaScript" type="text/javascript"> document.getElementById("ad9").innerHTML=document.getElementById("span_ad9").innerHTML; document.getElementById("span_ad9").innerHTML=""; </script>