劍心博客

          Just for java

            BlogJava :: 首頁(yè) :: 新隨筆 :: 聯(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ù)庫(kù)JDBC的應(yīng)用,如下例對(duì)數(shù)據(jù)庫(kù)的操作:

          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ù)庫(kù)操作辦法.

          在應(yīng)用中,經(jīng)常需要對(duì)數(shù)據(jù)庫(kù)操作,每次都寫(xiě)上述一段代碼肯定比較麻煩,需要將其中不變的部分提煉出來(lái),做成一個(gè)接口,這就引入了facade外觀對(duì)象.如果以后我們更換Class.forName中的<driver>也非常方便,比如從Mysql數(shù)據(jù)庫(kù)換到Oracle數(shù)據(jù)庫(kù),只要更換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)非常簡(jiǎn)單,所有程序?qū)?shù)據(jù)庫(kù)訪問(wèn)都是使用改接口,降低系統(tǒng)的復(fù)雜性,增加了靈活性.

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

          ?

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

          posted on 2006-12-11 19:44 powerwind 閱讀(114) 評(píng)論(0)  編輯  收藏 所屬分類(lèi): 轉(zhuǎn)來(lái)好帖java設(shè)計(jì)模式
          主站蜘蛛池模板: 长泰县| 常山县| 象山县| 万荣县| 仁怀市| 广昌县| 界首市| 乌兰察布市| 昆山市| 遵义县| 同江市| 江北区| 宝鸡市| 双城市| 丰城市| 上思县| 伊通| 本溪市| 阳谷县| 江城| 莱阳市| 漯河市| 滁州市| 颍上县| 密山市| 辛集市| 忻州市| 太仓市| 宁陵县| 宣化县| 新竹市| 香格里拉县| 延川县| 庆元县| 方城县| 黔西| 来凤县| 临城县| 长垣县| 景宁| 连江县|