`
生命火花
  • 浏览: 7855 次
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论
阅读更多

设计从简单开始,扩展从重构开始
优秀的设计是什么?并不是在初期就具有弹性,而是把业务压缩在若干个模型中,然后使用一套简单实用的接口让这些模型相互协作起来.扩展是什么?扩展是保持结构的松散,并非去支持有可能存在的逻辑.套用于后者的扩展通常会破坏抽象的原子性.使得一个抽象无法集中精力去做自己的事.我以为spring时代脱去架构师的黄金甲,用一套标准,实用,简单的框架结构为软件设计提供了一套简单明了的解决方案.设计者完全不必要从整体上去衡量设计的合理性,核心工作转变为需求到模型的抽象.

认真对待每一个异常
不要把异常认为是可以恢复的,当异常产生的时候要做"发生异常应该做的事",不要把异常当成一个变相的if/else,在里面写业务逻辑.

数据访问中缓存的策略
坚持做最有效的缓存!何为最有效的缓存?在业务结构中越靠上的缓存,价值越明显.但是不是所有的缓存都能提高质量的.只有一些读频繁但是写不频繁的对象才是最有缓存价值的对象.因为任何的缓存都会破坏数据,对象的一致性.并且会带来许许多多的隐藏问题.使用缓存一定要先确认被缓存的对象是否有cache的价值.

让事务发挥价值

事务存在的背景:

Data Access when multi object operate on the database

keep the procession in a atomicity

to make sure the data stay in a consistence state


通常为什么要使用事务?套用一个英文短语比较容易让人理解--"unit work".也就是说一个事务应该专注于一个业务流程.诸如删除用户和删除用户其他信息,假如只删除了用户但是删除其他信息失败了这不能算是一个完整的业务流程.应该把这个需求抽象成事务.

数据会话的时间要短而频

数据库表的设计要OO化
OO表设计的最终目的是饱和OR框架的Mapping机制,最大程度上体现组件的reuse.OO的成熟模型都可以抽象到数据库表里,eg.接口,抽象类,继承,多态,包括各种设计模式.一个足够OO的数据库可以从表的命名上看出来.

把配置文件当成资源直接部署到容器里
这样做的好处是,一旦配置被部署到容器中,则变成了一个全局的资源,这些资源由容器统一维护,这样会具有如下的灵活性
1:全局调用,由容器维护
2:方便处理分布式需求,
3:解除与辅助类之间的耦合
4:用j2ee的标准协议取代私有协议


数据访问策略中最不成熟的连接:many to many
我的立场,绝对不使用多对多的连接.一个多N:N的关系带来的性能损失是1*N.

为核心对象划分状态和身份
这一点在多线程的开发中是非常有意义的.
最佳的实践是使用与业务有关的键值来实现equals()和 hashCode() .
以Hibernate为例,如果你在Session外比较对象,你必须要实现equals()和 hashCode()。在Session内部,Java的对象识别可以值得信赖。如果你实现了这些方法,不要再使用数据库辨识!瞬时对象不具有标识值,Hibernate会在对象被保存的时候赋予它一个值。如果对象在被保存的时候位于Set内,hash code就会变化,要约就被违背。为了实现用与业务有关的键值编写equals()和 hashCode(),你应该使用类属性的唯一组合。记住,这个键值只是当对象位于Set内部时才需要保证稳定且唯一,并不是在其整个生命周期中都需要(不需要达到数据库主键这样的稳定性)。绝不要在equals()比较中使用集合(要考虑延迟装载),这些相关联的类可能被代理过。
Session会不时的向数据库同步持久化状态,如果这种操作进行的过于频繁,那么性能会受到一定的影响。有时候你可以通过禁止自动flushing尽量最小化非必要的flushing操作,或者更进一步,在一个特殊transaction中改变查询和其它操作的顺序。
在三层结构中,考虑使用 saveOrUpdate()
当使用一个servlet / session bean 的架构的时候, 你可以把已加载的持久对象在session bean层和servlet / JSP 层之间来回传递。使用新的session来为每个请求服务,使用 Session.update() 或者Session.saveOrUpdate()来更新对象的持久状态。
在两层结构中,记得自己关闭session.
当仅仅使用 servlet的时候,你可以在多个客户请求中复用同一个session,只是要记得在把控制权交还给客户端之前disconnect掉session。
为了得到最佳的可伸缩性,数据库事务(Database Transaction)应该尽可能的短。但是,程序常常需要实现长时间运行的“业务事务(Application Transaction)”,包含一个从用户的观点来看的原子操作。这个业务事务可能跨越多次从用户请求到得到反馈的循环。请使用离线对象(Detached Object),或者在两层结构中,把Hibernate Session从JDBC连接中脱离开,下次需要用的时候再连接上。绝不要在一个Session中包含多次业务事务,否则你的数据可能会过期失效。

对于关联优先考虑异步
面向客户的时代,对于那种用户接口频繁因为读取数据过慢而导致假死的现象的解决方案被提到手头,基于b/s的Ajax可以通过异步调用先把界面返回给用户,在后台用线程读取.早在ajax之前也可以使用activexObect来实现类似的功能,其目的只有一个,不要把dirty的界面丢在客户面前.其实解决这一问题的方案还有很多种,包括JMS,Laze loading等.


面向接口的编程习惯
现代化软件已经基本上摆脱了一个人搞定一套系统的旧模式,讲究的是协作.但是协作中,不同设计风格上的差异致使效率降低,java接口的标准规范了协作的流程,为团队开发引入了和谐的软件环境.使用接口,不仅仅兼容了各种设计风格,而且解除了调用上依赖关系.最大的吸引更在于,新时代的开源框架对于接口形式的业务提供了简单明了的支持.包括Aop,webservices等

分享到:
评论
2 楼 生命火花 2007-03-27  
NVN本来就是一个可以替代的方案!可以查看Hibernate Ref正对 NvN的替代方案
1 楼 hgq0011 2007-03-27  
”我的立场,绝对不使用多对多的连接.一个多N:N的关系带来的性能损失是1*N.“那多对多有什么好的替代方案吗?

相关推荐

    重要的J2EE最佳实践.doc

    本文档"重要的J2EE最佳实践.doc"主要讨论了两个关键点:始终使用MVC框架和在应用程序的每一层都进行自动单元测试和测试管理。 1. 始终使用MVC框架: MVC(Model-View-Controller)模式是J2EE应用程序设计的基础,...

    12个最重要的J2EE最佳实践

    ### 12个最重要的J2EE最佳实践 #### 1. 始终采用MVC框架 MVC(Model-View-Controller)架构模式在J2EE开发中扮演着核心角色,它通过清晰地区分业务逻辑、用户界面与流程控制,有效提升了软件的可维护性和扩展性。...

    中小型公司的j2ee 最佳实践

    这篇文档《中小型公司的J2EE最佳实践》虽然有些年份,但其核心理念和指导原则依然适用于当今的IT环境。以下将详细解析文档可能涵盖的关键知识点: 1. **系统架构设计**:文档可能会强调根据业务需求来选择合适的...

    Java高级-12个最重要的J2EE最佳实践

    以下是对"Java高级-12个最重要的J2EE最佳实践"的详细解释: 1. **模块化设计**:将应用分解为独立的模块,每个模块负责特定的功能,有利于代码复用和团队协作。使用Maven或Gradle等构建工具进行依赖管理。 2. **...

    探讨J2EE最佳实践

    本篇将深入探讨J2EE的最佳实践,帮助开发者实现高效、可扩展且易于维护的系统。 首先,J2EE的最佳实践之一是分层架构。这种架构模式将应用分为表示层、业务逻辑层和数据访问层,有助于分离关注点,提高代码复用性。...

    J2EE最佳实践

    ### J2EE最佳实践 #### 引言与背景 本书《O'Reilly – Java Enterprise Best Practices》主要聚焦于Java企业应用的最佳实践指南。通过详细分析和总结,为开发者提供了宝贵的指导,帮助他们在开发过程中遵循最佳...

    J2EE应用实践教程[郑阿奇][程序源代码

    《J2EE应用实践教程》是由郑阿奇编著的一本深入浅出的J2EE技术书籍,旨在帮助读者通过实际操作理解并掌握J2EE应用...通过深入研究源代码,可以更深入地理解J2EE的设计模式和最佳实践,为日后的项目开发打下坚实的基础。

    j2ee Best Practice.pdf

    根据提供的文档内容,我们可以深入探讨J2EE最佳实践的关键知识点,包括其背景、目标、基本原则以及具体的实践案例。 ### J2EE 最佳实践简介 #### 什么是 J2EE 最佳实践? J2EE(Java 2 Platform, Enterprise ...

    J2EE的潜在难点及最佳实践

    ### J2EE的潜在难点及最佳实践 #### 绪论 Java 2 Platform, Enterprise Edition (J2EE) 是一种广泛应用于企业级软件开发的技术框架,由一系列相关的规范组成,旨在提供一个统一的标准来实现和部署企业应用。J2EE ...

    J2EE开发最佳实践

    在J2EE(Java 2 Platform, Enterprise Edition)开发中,遵循最佳实践是确保应用程序高效、可维护和扩展的关键。本篇文章将详细阐述两个核心的最佳实践:一是始终使用MVC(Model-View-Controller)架构模式,二是...

    J2EE开发最佳实践PPT.ppt

    在J2EE(Java EE,即Java平台企业版)开发中,遵循最佳实践至关重要,因为它们可以帮助提升应用程序的性能、可维护性和可扩展性。以下是一些关键的J2EE开发最佳实践,主要从IBM IT Education Services的分享中提炼...

    j2ee best practise

    《J2EE最佳实践》是Java企业级应用开发的重要指南,涵盖了从设计、开发到部署的一系列关键知识点。本文将深入探讨这些最佳实践,旨在帮助开发者优化J2EE应用程序的性能、可维护性和扩展性。 1. **模块化设计**:在...

    J2EE体系结构及其主要设计模式

    #### J2EE最佳实践 **2.1 开发过程控制** - **2.1.1 风险及早发现**:通过持续集成和代码审查等方法尽早识别潜在的风险。 - **2.2 设计阶段** - **2.2.1 设计应适应环境的变化**:设计时考虑到未来可能的需求变化...

Global site tag (gtag.js) - Google Analytics