從橋接模式與策略模式談起

          橋接(Bridge)模式是結構型模式的一種,而策略(strategy)模式則屬于行為模式。以下是它們的UML結構圖。

          在橋接模式中,Abstraction通過聚合的方式引用Implementor。

           

          在策略模式中,Context也使用聚合的方式引用Startegy抽象接口。

           

          從他們的結構圖可知,在這兩種模式中,都存在一個對象使用聚合的方式引用另一個對象的抽象接口的情況,而且該抽象接口的實現可以有多種并且可以替換。可以說兩者在表象上都是調用者與被調用者之間的解耦,以及抽象接口與實現的分離。

          那么兩者的區別體現在什么地方呢?

          1. 首先,在形式上,兩者還是有一定區別的,對比兩幅結構圖,我們可以發現,在橋接模式中不僅Implementor具有變化(ConcreateImplementior),而且Abstraction也可以發生變化(RefinedAbstraction),而且兩者的變化是完全獨立的,RefinedAbstraction與ConcreateImplementior之間松散耦合,它們僅僅通過Abstraction與Implementor之間的關系聯系起來。而在策略模式中,并不考慮Context的變化,只有算法的可替代性。

          2. 其次在語意上,橋接模式強調Implementor接口僅提供基本操作,而Abstraction則基于這些基本操作定義更高層次的操作。而策略模式強調Strategy抽象接口的提供的是一種算法,一般是無狀態、無數據的,而Context則簡單調用這些算法完成其操作。

          3. 橋接模式中不僅定義Implementor的接口而且定義Abstraction的接口,Abstraction的接口不僅僅是為了與Implementor通信而存在的,這也反映了結構型模式的特點:通過繼承、聚合的方式組合類和對象以形成更大的結構。在策略模式中,Startegy和Context的接口都是兩者之間的協作接口,并不涉及到其它的功能接口,所以它是行為模式的一種。行為模式的主要特點就是處理的是對象之間的通信方式,往往是通過引入中介者對象將通信雙方解耦,在這里實際上就是將Context與實際的算法提供者解耦。

          所以相對策略模式,橋接模式要表達的內容要更多,結構也更加復雜。橋接模式表達的主要意義其實是接口隔離的原則,即把本質上并不內聚的兩種體系區別開來,使得它們可以松散的組合,而策略在解耦上還僅僅是某一個算法的層次,沒有到體系這一層次。從結構圖中可以看到,策略的結構是包容在橋接結構中的,橋接中必然存在著策略模式,Abstraction與Implementor之間就可以認為是策略模式,但是橋接模式一般Implementor將提供一系列的成體系的操作,而且Implementor是具有狀態和數據的靜態結構。而且橋接模式Abstraction也可以獨立變化。

           

          參考:呂震宇的設計模式隨筆——蠟筆與毛筆的故事

          Bridge Strategy 和State的區別 后續的討論,很有啟發。

          posted on 2007-04-25 15:44 雁過無痕 閱讀(6412) 評論(3)  編輯  收藏

          評論

          # re: 從橋接模式與策略模式談起[未登錄] 2007-11-16 09:11 Steve

          Good article!  回復  更多評論   

          # re: 從橋接模式與策略模式談起 2008-08-30 19:18 henryoung

          很好 終于理解了 主要從結構和實習上來區別
            回復  更多評論   

          # re: 從橋接模式與策略模式談起 2013-12-02 14:52 awu

          這樣一說,原來差別主要在細節上。  回復  更多評論   


          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          <2013年12月>
          24252627282930
          1234567
          891011121314
          15161718192021
          22232425262728
          2930311234

          導航

          統計

          常用鏈接

          留言簿(7)

          隨筆檔案

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 调兵山市| 大邑县| 陵水| 塔河县| 达日县| 海林市| 菏泽市| 山东省| 应城市| 陆川县| 义乌市| 鲜城| 凭祥市| 唐河县| 肃宁县| 绥德县| 江北区| 壶关县| 什邡市| 秦皇岛市| 博罗县| 石家庄市| 枝江市| 华亭县| 龙川县| 乌鲁木齐县| 区。| 天等县| 平塘县| 石嘴山市| 新沂市| 宁都县| 苍山县| 陆川县| 济宁市| 湘乡市| 汤原县| 山阴县| 吐鲁番市| 商南县| 竹溪县|