`
Surmounting
  • 浏览: 62468 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

刚有人问面试题咋答,一时兴起回了下,关于对 Struts2, Spring 和 Hibernate 的理解

阅读更多

Struts2, Spring 和 Hibernate 的理解之我谈

某人提出的问题:
大家好,我是应届毕业生,我在找工作时候,面试官问我:用自己的话分别谈谈对 struts2,spring,Hibernate的理解,我应该怎么说啊?求高人指点。(不要那些官方语言)


我的回答:
Struts2 是基于 Filter 进行跳转控制的工具,封装了从不同请求路径到不同程序的分发过程。我个人觉得这种分发应该根据系统的预期复杂程度来决定是否使用。毕竟,基于反射的框架工具,都会带来执行速度的缓慢。这意味着同样规模的用户,服务器需要消耗避免反射型框架 十倍以上的内存。
   对于页面跳转,我个人认为应该将软件结构设计成网络传输与数据功能分开的模式。这种模式意味着,同一种网络请求,就对应某一个程序程序。由这些和访问直 接对应的程序方法来进行各种功能的组合调用。这么做是因为,在实际系统中,这种组合而来的功能流程,对于一个系统来说,是几乎不会临时改变的。就算能够改 变,也不方便通过让实施人员调整配置文件来达成这种变化。
  另外,如果网络和客户端(运行 JavaScript 的浏览器本身也可以理解为一种客户端)的数据交互,如果能够提纯,也就能在一定程度上解决对复杂跳转控制的依赖,从而不使用 Struts 及类似产品。具体单页面应用 的有关内容,有机会再说吧。

Spring 主要的功能是对象依赖关系的注入,以及方法执行前、后的监视(切片)。在实现途径上,通过 Spring 执行的每一个方法,都不是直接执行,而是通过代理程序的方式。这严重损害了服务器性能。
  还是刚才的观点,我认为软件结构的设计,可以避免很多系统曾经出现的问题,比如依赖层次过多造成人工控制困难,等。
  通过 Spring 进行切片是一个具备很高开发效率的方式。不过因为性能严重低下,所以内网系统可以考虑。公网系统,则应该通过可配置的模块化功能执行流程,来避免代码重复编写。

Hibernate 是对象-关系转换工具,并且能够在软件层面实现分布式事务 。 不过就像 Spring 一样,其性能也完全无法得到保证。我之前没有研究过分布式事务如何实现。不过考虑到数据安全问题,现实中数据库一般并不会向外网透露。这造成了分布式事务 在绝大多数项目中缺乏实用意义。对象-关系转换,其实也是因为 Java 对于数据处理的僵死,不像现在新语种那样能够轻松往已经存在的对象中添加属性。
  可以考虑自定义基于 Map 的数据结构,以简便地和关系型数据库进行对应。这样能够很大程度摆脱对对象-关系转换工具的依赖。

本文也在我的 CSDN 空间发表: http://blog.csdn.net/shanelooli/article/details/8128567

分享到:
评论
2 楼 Surmounting 2012-11-03  
de6566088 写道
看到楼主的回答,感觉楼主对SSH存在相当大的一种不屑情绪,刚开始读的时候这哪是是在回答面试题目,明显是在抢人。后来看了看楼主的整体文章,发现楼主是个喜欢专研调优的人么。其实框架这东西并不是说常用就是一定是完美的,而是一种适合,这些框架其实就是一个基础性的东西,每个公司的架构师都是要根据情况要对其进行调优改进的,而且还要考虑到手下人员的接受能力和上手速度,这是个综合因素,并不是唯有效率快就好。面试的目的每个面试官不同,想要的答案也不唯一,还是那么说合适的才是最好的。


我其实都没想到这个话题能在论坛那边造成讨论。我原来只是不想我写的字流失掉……
http://www.iteye.com/topic/1127474
已经讨论了很多了。确实,对于计算资源冗余的系统,运行速度不重要。
1 楼 de6566088 2012-10-31  
看到楼主的回答,感觉楼主对SSH存在相当大的一种不屑情绪,刚开始读的时候这哪是是在回答面试题目,明显是在抢人。后来看了看楼主的整体文章,发现楼主是个喜欢专研调优的人么。其实框架这东西并不是说常用就是一定是完美的,而是一种适合,这些框架其实就是一个基础性的东西,每个公司的架构师都是要根据情况要对其进行调优改进的,而且还要考虑到手下人员的接受能力和上手速度,这是个综合因素,并不是唯有效率快就好。面试的目的每个面试官不同,想要的答案也不唯一,还是那么说合适的才是最好的。

相关推荐

Global site tag (gtag.js) - Google Analytics