Chinaunix首页 | 论坛 | 博客
  • 博客访问: 14490209
  • 博文数量: 5645
  • 博客积分: 9880
  • 博客等级: 中将
  • 技术积分: 68081
  • 用 户 组: 普通用户
  • 注册时间: 2008-04-28 13:35
文章分类

全部博文(5645)

文章存档

2008年(5645)

我的朋友

分类:

2008-04-28 21:39:04

下载本文示例代码
  从重构的角度学习bridge设计模式   Bridge模式是一个在实际系统中经常应用的模式。它最能体现设计模式的原则针对接口进行编程,和使用聚合不使用继承这两个原则。   由于我们过分的使用继承,使类的结构过于复杂,不易理解,难以维护。特别是在Java中由于不能同时继承多个类,这样就会造成多层继承,维护更难。  Bridge模式是解决多层继承的根本原因。如果你在实现应用中一个类,需要继承两个以上的类,并且这两者之间又持有某种关系,它们两个都会有多种变化。  Bridge模式是把这两个类,分解为一个抽象,一个实现,使它们两个分离,这样两种类可以独立的变化。  抽象就是,把一个实体的共同概念(相同的步骤),抽取出来(分解出几个相互独立的步骤),作为一个过程。如我们把数据库的 操作抽象为一个过程,有几个步骤,创建SQL语句,发送到数据库处理,取得结果。   实现就是怎样完成这个抽象步骤,如发送到数据库,需要结合具体的数据库,考虑怎样完成这个步骤等。并且同一步骤可能存在不同的实现,如对不同的数据库需要不同的实现。   现在我们假设一个情况,也是WEB中经常遇到的,在一个page有输入框,如客户信息的姓名,地址等,输入信息后,然后按查找按钮,把查找的结果显示出来。  我们现在假设查找客户信息和帐户信息,它们在不同的表中。  但是我们的系统面对两种人群,总部的它们信息保存到oracle数据库,但是各个分公司的数据保存在Sybase中,数据库的位置等各不相同,这两种的操作不同。   下面是我们一般首先会使用的方式,使用if else进行,判断,这样使用系统难以维护,难以扩展,不妨你增加一种查询,或者一种数据库试试? public class SearchAction(){ public Vector searchData(string ActionType,String DbType){String SQL=""; if(ActionType.equal("查找客户信息")){//如果是查询客户信息,拼SQL语句从客户表中读取数据SQL="select * from Customer " if(dbType.equal("oracle")){//从总部数据库读取,数据库为OracleString connect_string ="jdbc:oracle:thin:hr/hr@localhost:1521:HRDB";DriverManager.registerDriver (new oracle.jdbc.OracleDriver()); Connection conn = DriverManager.getConnection (connect_string);// Create a statementStatement stmt = conn.createStatement ();ResultSet rset = stmt.executeQuery (SQL);//以下省略部分动态从数据库中取出数据,组装成Vector,返回..................................................................... }else(dbType.equal("sybase")){//从分公司数据库读取,数据库为SybaseString connect_string ="jdbc:sybase:Tds:cai/cai@192.168.1.12:1521:FIN";DriverManager.registerDriver (new com.sybase.jdbc.SybDriver()); Connection conn = DriverManager.getConnection (connect_string);// Create a statementStatement stmt = conn.createStatement ();ResultSet rset = stmt.executeQuery (SQL);//以下省略部分动态从数据库中取出数据,组装成Vector,返回..................................................................... } }else if(ActionType.equal("查找帐户信息")){//如果是查询帐户信息,拼接SQL语句从帐户表中读取数据SQL="select * from Account "if(dbType.equal("oracle")){....................................................(作者注:此处省略从oracle读取,约300字) }else if(dbType.equal("Sybase")){....................................................(作者注:此处省略从Sybase读取,约300字) } } }}   如果你认为这写的比较弱智,应该进行使用函数,但是你也会大量使用if else。 共2页。 1 2 :   从重构的角度学习bridge设计模式   Bridge模式是一个在实际系统中经常应用的模式。它最能体现设计模式的原则针对接口进行编程,和使用聚合不使用继承这两个原则。   由于我们过分的使用继承,使类的结构过于复杂,不易理解,难以维护。特别是在Java中由于不能同时继承多个类,这样就会造成多层继承,维护更难。  Bridge模式是解决多层继承的根本原因。如果你在实现应用中一个类,需要继承两个以上的类,并且这两者之间又持有某种关系,它们两个都会有多种变化。  Bridge模式是把这两个类,分解为一个抽象,一个实现,使它们两个分离,这样两种类可以独立的变化。  抽象就是,把一个实体的共同概念(相同的步骤),抽取出来(分解出几个相互独立的步骤),作为一个过程。如我们把数据库的 操作抽象为一个过程,有几个步骤,创建SQL语句,发送到数据库处理,取得结果。   实现就是怎样完成这个抽象步骤,如发送到数据库,需要结合具体的数据库,考虑怎样完成这个步骤等。并且同一步骤可能存在不同的实现,如对不同的数据库需要不同的实现。   现在我们假设一个情况,也是WEB中经常遇到的,在一个page有输入框,如客户信息的姓名,地址等,输入信息后,然后按查找按钮,把查找的结果显示出来。  我们现在假设查找客户信息和帐户信息,它们在不同的表中。  但是我们的系统面对两种人群,总部的它们信息保存到oracle数据库,但是各个分公司的数据保存在Sybase中,数据库的位置等各不相同,这两种的操作不同。   下面是我们一般首先会使用的方式,使用if else进行,判断,这样使用系统难以维护,难以扩展,不妨你增加一种查询,或者一种数据库试试? public class SearchAction(){ public Vector searchData(string ActionType,String DbType){String SQL=""; if(ActionType.equal("查找客户信息")){//如果是查询客户信息,拼SQL语句从客户表中读取数据SQL="select * from Customer " if(dbType.equal("oracle")){//从总部数据库读取,数据库为OracleString connect_string ="jdbc:oracle:thin:hr/hr@localhost:1521:HRDB";DriverManager.registerDriver (new oracle.jdbc.OracleDriver()); Connection conn = DriverManager.getConnection (connect_string);// Create a statementStatement stmt = conn.createStatement ();ResultSet rset = stmt.executeQuery (SQL);//以下省略部分动态从数据库中取出数据,组装成Vector,返回..................................................................... }else(dbType.equal("sybase")){//从分公司数据库读取,数据库为SybaseString connect_string ="jdbc:sybase:Tds:cai/cai@192.168.1.12:1521:FIN";DriverManager.registerDriver (new com.sybase.jdbc.SybDriver()); Connection conn = DriverManager.getConnection (connect_string);// Create a statementStatement stmt = conn.createStatement ();ResultSet rset = stmt.executeQuery (SQL);//以下省略部分动态从数据库中取出数据,组装成Vector,返回..................................................................... } }else if(ActionType.equal("查找帐户信息")){//如果是查询帐户信息,拼接SQL语句从帐户表中读取数据SQL="select * from Account "if(dbType.equal("oracle")){....................................................(作者注:此处省略从oracle读取,约300字) }else if(dbType.equal("Sybase")){....................................................(作者注:此处省略从Sybase读取,约300字) } } }}   如果你认为这写的比较弱智,应该进行使用函数,但是你也会大量使用if else。 共2页。 1 2 : 下载本文示例代码


从重构的角度学习bridge设计模式从重构的角度学习bridge设计模式从重构的角度学习bridge设计模式从重构的角度学习bridge设计模式从重构的角度学习bridge设计模式从重构的角度学习bridge设计模式从重构的角度学习bridge设计模式从重构的角度学习bridge设计模式从重构的角度学习bridge设计模式从重构的角度学习bridge设计模式从重构的角度学习bridge设计模式从重构的角度学习bridge设计模式从重构的角度学习bridge设计模式从重构的角度学习bridge设计模式从重构的角度学习bridge设计模式
阅读(116) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~