当前位置:主页   - 电脑 - 程序设计 - JAVA
JavaBeans:游离实体
来源:网络   作者:   更新时间:2012-06-15
收藏此页】    【字号    】    【打印】    【关闭

  当transaction scope persistence context或extended persistence context结束之后,实体的实例就会不受托管而处于游离状态。游离实体的一个值得注意的特征是,它可以被序列化并通过网络发送给远程客户端。客户端可以修改这些经过序列化的对象实例,并将它们发送回服务器,服务器再将客户端的修改重新合并到数据库中。

  这与EJB 2.1的实体模型有很大的不同。在EJB 2.1中,实体是始终受容器管理的,使用entity bean的应用程序总要带一个指向entity bean的代理(译注:proxy,即远程接口或本地接口);而在EJB 3.0中,你是直接与普通Java类的具体实例打交道的。对于EJB 2.1的开发人员而言,上述做法乍一看会觉得有些不适应,因为他们已经习惯了容器来为实体打点一切。不过,一旦你熟悉了新的EJB 3.0实体模型,就会发现,你的应用程序代码将大幅缩减,并且更易于管理。

  EJB 2.1的代码中时常使用Value Object模式(也被称为Data Transfer Objects)。该模式的主要思想是:让entity bean暴露一个方法,该方法将bean的全部状态复制到一个对象中,此对象可以被序列化到远程客户端(比如Swing应用程序),以供远程客户端访问。

  // EJB 2.1 entity bean 类
  public class CustomerBean implements javax.ejb.EntityBean {
    CustomerValueObject getCustomerVO() {
    return new CustomerValueObject(getFirstName(), getLastName(),
    getStreet(), getCity(), getState, getZip());
    }
  }

  在客户端对entity bean进行远程方法调用需要较大的系统开销。如果客户端必须通过调用getFirstName(),getLastName()等一系列方法才能获得用于显示的客户相关信息,那么性能将变得不堪重负。这便是Value Object模式的由来。而EJB 3.0中,由于持久对象在脱离persistence context之后将自动变成值对象,因此也就没必要再使用该模式了。

其它资源
来源声明

版权与免责声明
1、本站所发布的文章仅供技术交流参考,本站不主张将其做为决策的依据,浏览者可自愿选择采信与否,本站不对因采信这些信息所产生的任何问题负责。
2、本站部分文章来源于网络,其版权为原权利人所有。由于来源之故,有的文章未能获得作者姓名,署“未知”或“佚名”。对于这些文章,有知悉作者姓名的请告知本站,以便及时署名。如果作者要求删除,我们将予以删除。除此之外本站不再承担其它责任。
3、本站部分文章来源于本站原创,本站拥有所有权利。
4、如对本站发布的信息有异议,请联系我们,经本站确认后,将在三个工作日内做出修改或删除处理。
请参阅权责声明