点击这里给我发消息 点击这里给我发消息

EJB设计模式4

添加时间:2013-12-7
    相关阅读: 设计 开发 数据库 维护

  在设计模式3中我们看到使bean从struct继承后使得代码大幅缩水并且所有的字段都可定义为cmp字段。这里,我们可以更进一步修正setdata()和getdata()的实现方法来减少代码量。
  我们为这个struct增加一个方法。
  value Object code snippet for Company
  public class CompanyStruct implements
  java.io.Serializable {
  public Integer comId;
  public String comName;
  public String comDescription;
  public Timestamp mutationDate;
  public void copyFrom(CompanyStruct struct) {
  comId = struct.comId;
  comName = struct.comName;
  comDescription = struct.comDescription;
  mutationDate = struct.mutationDate;
  }
  }
  
  由于entity bean是从struct继承下来的,在bean的实现类中也一样可以引用copyfrom()方法,当然,必须注意的是,这个copyfrom()方法并不是一个商业方法,它不需要在bean的远程接口中暴露给调用者。
  现在,getdata()和setdata()方法可以简化更进一步的简化。
  Code snippet for an Entity Bean’s getData()
  public CompanyStruct getData() {
  CompanyStruct result = new CompanyStruct();
  result.copyFrom(this);
  return result;
  }
  
  这里把this作为一个参数传入copyfrom()。由于enttity bean从struct继承而来,于是这个entitty bean便可以作为一个struct传入。
  EJB容器并不赞成把this指针作为一个参数传递因为在两个控制线程中同时访问一个bean的实例可能会引起事务冲突。但事实上我们所做的并没有违背这个原则,因为我们的并没有在bean之间传递this的引用并且也没有引用任何可能引起事务冲突的方法。
  Code snippet for an Entity Bean’s setData()
  public void setData(CompanyStruct struct) {
  this.copyFrom(struct);
  }
  
  对于一个映射到有很多列的表的entity bean,这种实现方法的优点是使得bean实现类的代码非常简单。这种设计模式使得代码及其精简,可读性和可维护性也大大增强。任何数据库的修改都只需要修改作为基类的struct,而几乎不需要修改bean的代码。把这种改变从struct分离出来,当cmp字段发生改变时需要修改部署描述符。这就使得开发时能够更好的适应设计的改变。
  这里,还是没有实现bean之间的关系,这将在设计模式5中解决。
咨询热线:020-85648757 85648755 85648616 0755-27912581 客服:020-85648756 0755-27912581 业务传真:020-32579052
广州市网景网络科技有限公司 Copyright◎2003-2008 Veelink.com. All Rights Reserved.
广州商务地址:广东省广州市黄埔大道中203号(海景园区)海景花园C栋501室
= 深圳商务地址:深圳市宝源路华丰宝源大厦606
研发中心:广东广州市天河软件园海景园区 粤ICP备05103322号 工商注册