劍心博客

          Just for java

            BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
            1 隨筆 :: 29 文章 :: 1 評(píng)論 :: 0 Trackbacks

          設(shè)計(jì)模式之Facade(外觀 總管 Manager)

          板橋里人 http://www.jdon.com 2002/4/6/(轉(zhuǎn)載請(qǐng)保留)

          Facade模式的定義 : 為子系統(tǒng)中的一組接口提供一個(gè)一致的界面.

          Facade一個(gè)典型應(yīng)用就是數(shù)據(jù)庫JDBC的應(yīng)用,如下例對(duì)數(shù)據(jù)庫的操作:

          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中最通常的對(duì)數(shù)據(jù)庫操作辦法.

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

          我們做成了一個(gè)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;
            }
          }

          可見非常簡(jiǎn)單,所有程序?qū)?shù)據(jù)庫訪問都是使用改接口,降低系統(tǒng)的復(fù)雜性,增加了靈活性.

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

          ?

          由上圖可以看出, facade實(shí)際上是個(gè)理順系統(tǒng)間關(guān)系,降低系統(tǒng)間耦合度的一個(gè)常用的辦法,也許你已經(jīng)不知不覺在使用,盡管不知道它就是facade.

          posted on 2006-12-11 19:44 powerwind 閱讀(111) 評(píng)論(0)  編輯  收藏 所屬分類: 轉(zhuǎn)來好帖 、java設(shè)計(jì)模式
          主站蜘蛛池模板: 长岭县| 永德县| 宝兴县| 盐城市| 靖安县| 永寿县| 高密市| 开鲁县| 剑川县| 海兴县| 遂宁市| 香格里拉县| 合肥市| 渝北区| 玛多县| 黔西| 永清县| 江华| 伊宁市| 仙桃市| 汶川县| 平顶山市| 洪江市| 平阴县| 淮南市| 漠河县| 丹阳市| 青神县| 土默特右旗| 龙泉市| 周至县| 偃师市| 香港 | 临猗县| 博爱县| 家居| 赫章县| 澜沧| 兰西县| 永定县| 鄂伦春自治旗|