posts - 73,  comments - 55,  trackbacks - 0
          Facade模式的定義 : 為子系統中的一組接口提供一個一致的界面.。現在的軟件都是按照模塊進行劃分,對不同的模塊分別進行編程。但是在用戶開來,不同的模塊應該具有統一的接口,換句話說,我們應該可以通過統一的接口訪問系統中的所有功能。

          ??? 有一個很典型的例子就是編譯系統。通常我們將編譯系統分解為:Compile和Link兩個步驟。一個Compile又可以分解為詞法分析、語法分析、語義分析、中間代碼生成等等步驟。對于用戶來講,我們不可能將這些模塊分別提供給他們,讓他們依次調用。相反的,我們應該提供一個統一的接口,使得用戶可以方便的使用各個功能,例如IDE 。

          Facade一個典型應用就是數據庫JDBC的應用,如下例對數據庫的操作:

          public class DBCompare {

            Connection conn = null;
            PreparedStatement prep = null;
            ResultSet rset = null;
            try {
               Class.forName( "<driver>" ).newInstance();
               conn = DriverManager.getConnection( "<database>" );
              
               String sql = "SELECT * FROM <table> WHERE <column name> = ?";
               prep = conn.prepareStatement( sql );
               prep.setString( 1, "<column value>" );
               rset = prep.executeQuery();
               if( rset.next() ) {
                  System.out.println( rset.getString( "<column name" ) );
               }
            } catch( SException e ) {
               e.printStackTrace();
            } finally {
               rset.close();
               prep.close();
               conn.close();
            }
          }

          上例是Jsp中最通常的對數據庫操作辦法.

          在應用中,經常需要對數據庫操作,每次都寫上述一段代碼肯定比較麻煩,需要將其中不變的部分提煉出來,做成一個接口,這就引入了facade外觀對象.如果以后我們更換Class.forName中的<driver>也非常方便,比如從Mysql數據庫換到Oracle數據庫,只要更換facade接口中的driver就可以.

          我們做成了一個Facade接口,使用該接口,上例中的程序就可以更改如下:

          public class DBCompare {

            String sql = "SELECT * FROM <table> WHERE <column name> = ?";  

            try {
               Mysql msql=new mysql(sql);
               prep.setString( 1, "<column value>" );
               rset = prep.executeQuery();
               if( rset.next() ) {
                  System.out.println( rset.getString( "<column name" ) );
               }
            } catch( SException e ) {
               e.printStackTrace();
            } finally {
               mysql.close();
               mysql=null;
            }
          }

          可見非常簡單,所有程序對數據庫訪問都是使用改接口,降低系統的復雜性,增加了靈活性.

          如果我們要使用連接池,也只要針對facade接口修改就可以.

          ?

          由上圖可以看出, facade實際上是個理順系統間關系,降低系統間耦合度的一個常用的辦法,也許你已經不知不覺在使用,盡管不知道它就是facade.

          posted on 2006-07-10 17:15 保爾任 閱讀(293) 評論(0)  編輯  收藏 所屬分類: Design Patten

          <2025年5月>
          27282930123
          45678910
          11121314151617
          18192021222324
          25262728293031
          1234567

          常用鏈接

          留言簿(4)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 鄢陵县| 广南县| 丰城市| 喀喇沁旗| 鄢陵县| 白银市| 满城县| 铜山县| 永和县| 河南省| 溧阳市| 石林| 江达县| 宁强县| 海口市| 芮城县| 商南县| 缙云县| 朝阳区| 潼关县| 夏津县| 邮箱| 瑞金市| 石渠县| 视频| 年辖:市辖区| 灌阳县| 玛多县| 长治县| 固始县| 峨山| 涿州市| 交口县| 天镇县| 维西| 新营市| 筠连县| 昭觉县| 龙门县| 高碑店市| 岚皋县|