劍心博客

          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ù)操作,每次都寫上述一段代碼肯定比較麻煩,需要將其中不變的部分提煉出來,做成一個(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)單,所有程序?qū)?shù)據(jù)庫(kù)訪問都是使用改接口,降低系統(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 閱讀(113) 評(píng)論(0)  編輯  收藏 所屬分類: 轉(zhuǎn)來好帖java設(shè)計(jì)模式
          主站蜘蛛池模板: 富蕴县| 丰都县| 锡林郭勒盟| 绥江县| 韶山市| 高唐县| 鹤庆县| 平遥县| 成武县| 岳池县| 犍为县| 冕宁县| 成安县| 尉犁县| 迁安市| 左权县| 青龙| 三穗县| 聊城市| 上栗县| 宝坻区| 天等县| 新营市| 乐陵市| 太原市| 衡东县| 南和县| 潍坊市| 霍城县| 方正县| 阳山县| 申扎县| 开鲁县| 修水县| 平顶山市| 青龙| 崇信县| 囊谦县| 湟源县| 柞水县| 攀枝花市|