java架构有哪些

软件架构做为一个概念,体如今技术和业务两个方面。java

从技术角度来讲:软件架构随着技术的革新不断地更新其内容,软件架构创建于当前技术和一些基本原则c++

的基础之上。web

先说一些基本原则:spring

分层原则:分层是为了下降软件深度复杂性而使用的关键思想,就像社会有了阶级同样,软件有了层次结构。数据库

模块化原则:模块化是化解软件广度复杂的必然手段,模块化的目的就是让软件分工。编程

接口实现分离原则随着软件模块化的不断深刻改进,面向接口编程而不是面向实现编程可让复杂度日趋增高的软件下降模块之间的耦合度,从而让各模块更轻松改进。从这个原则出发,软件也从微观进行了细致的规范化。设计模式

还有两个比较小但很重要的原则:session

细节隐藏原则很显然把复杂问题简化,把难看的细节隐去,能让软件结构更清晰。其实这个原则使用很广泛,java/c++语言中的封装原则以及设计模式中的Facade(外观)模式就很能体现这个原则的精神。架构

依赖倒置原则随着软件结构的进一步发展,层与层之间、模块与模块之间的依赖逐渐加深,而层、模块的动态可插拔要求不端增大。框架

依赖倒置原则可看视为接口实现分离原则的深化,根据此原则的精神,软件进入了工具时代。这个原则有点相似于知名的好莱坞法则:Don't call us, we'll call you。

以上这些原则奠基了咱们的软件架构的价值指标。但软件架构毕竟是创建在当前技术之上的。而每一代技术都有架构模式。过去的再也不说了,让咱们如今就来看一下当前流行的技术,以及当前咱们能采用的架构。

由于面向对象是当前最流行开发技术,且设计模式的大量使用使面向对象的走向成熟,而数据库是当前最有效的存储结构、web界面是当前最流行的用户接口,因此当前最典型的三层次架构就架构在以上几项技术的基础之上,用数据库做存储层、用面向对象来实现业务层、用web来做为用户接口层。

咱们从三层次架构谈起:

由于面向对象技术和数据库技术不适配,因此在标准三层次架构的基础上,咱们增长了数据持久层,来管理O-R双向映射,但目前一直没有最理想的实现技术。cmp和entity bean技术由于其实现复杂,功能前景有限,已接近被淘汰的边缘。JDO及hibernate做为o-r映射的后期之秀,尤为是hibernate,功能至关完备。推荐做为持久层的首选

在业务层,由于当前业务日趋负载,且变更频繁,因此咱们必须有足够敏捷的技术来保证咱们的适应变化的能力,在标准j2ee系统中session bean负责业务处理,且有不错的性能表现,但采用ejb系统对业务架构模式改变太大,且其复杂而昂贵,业务代码移植性差。

而spring 做为一个bean配置的轻量级架构,漂亮的IOC模式实现,对业务架构影响小,因此推荐做为中间层业务框架。

在用户结构层,虽然servlet/jsp/jstl/javaBean 可以实现MVC架构,但终究过于粗糙。struts对MVC架构的实现就比较完美,Taperstry也极好地实现MVC架构,且采用基于事件的方式,很是诱人,惜其不够成熟,咱们仍旧推荐struts做为用户接口层基础架构。

相关文章
相关标签/搜索