Facade模式的定義
: 為子系統(tǒng)中的一組接口提供一個(gè)一致的界面.。現(xiàn)在的軟件都是按照模塊進(jìn)行劃分,對(duì)不同的模塊分別進(jìn)行編程。但是在用戶開(kāi)來(lái),不同的模塊應(yīng)該具有統(tǒng)一的接口,換句話說(shuō),我們應(yīng)該可以通過(guò)統(tǒng)一的接口訪問(wèn)系統(tǒng)中的所有功能。
??? 有一個(gè)很典型的例子就是編譯系統(tǒng)。通常我們將編譯系統(tǒng)分解為:Compile和Link兩個(gè)步驟。一個(gè)Compile又可以分解為詞法分析、語(yǔ)法分析、語(yǔ)義分析、中間代碼生成等等步驟。對(duì)于用戶來(lái)講,我們不可能將這些模塊分別提供給他們,讓他們依次調(diào)用。相反的,我們應(yīng)該提供一個(gè)統(tǒng)一的接口,使得用戶可以方便的使用各個(gè)功能,例如IDE 。
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-07-10 17:15
保爾任 閱讀(300)
評(píng)論(0) 編輯 收藏 所屬分類(lèi):
Design Patten