<b>筹划情势之Facade(外观)</b>[Java编程]
本文“<b>筹划情势之Facade(外观)</b>[Java编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
Facade的定义:为子系统中的一组接口供应一个一致的界面.
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.
以上是“<b>筹划情势之Facade(外观)</b>[Java编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |