Java 已经发展了近20年,极其丰富的周边框架打造了一个繁荣稳固的生态圈
JavaEE 框架,从百家混战到现在 Spring 基本一统天下
Web 开发,从标配的 SSH 到现在 SpringMVC + MyBatis 组合
IDE,从当年如火如荼的 JBuilder 到 Eclipse,再到更好用的 IDEA
随着时间推移,一些优秀的框架崭露头角,一些低效框架也慢慢退出历史舞台
今天,我们就来看看有哪些框架,以后可以不用学啦
JSP
JSP在实际开发中,主要是作为 MVC 模型中的 V(View)层出现的。当然,View 层的渲染技术除了JSP,还有 FreeMaker、Velocity 等。
JSP 作为页面模板,在后端通过 MVC 框架渲染成 HMTL,然后再发送到客户端(例如浏览器)来呈现。这也就是我们常说的“前后端不分离”,“混合式”开发。
而当前,包括我所在的公司,以及大部分互联网公司。要么已经抛弃这种模式,要么正在抛弃的路上,而转向彻底的“前后端分离”。
在“前后端分离”模式下,后端只负责提供服务接口(例如 REST),而前端(例如 HTML5)通过接口发送/获取,呈现数据(例如 JSON 格式)。
这样,在后端,原来的MVC框架,某种意义上已经演变为 MC 框架。因此,与V(View)相关的一切模板技术都失去了学习的必要,其中当然也包括 JSP。所以,后来的 Java 学习者,我的建议是:
“完全可以放弃对 JSP 的学习。”
Struts
在 Java 后端开发中,MVC 模型还是主流。而 Struts 作为一个 MVC 框架,单从技术上来说,还是很优秀的。
但是,现在 Spring 实在是太强势了,越来越成为 Java 开发中的“一站式”工具包,其中的一个利器就是 Spring MVC。
望名知意,Spring MVC 也是一个 MVC 框架。而且因为它是 Spring 的亲儿子,自然和 Spring 契合的非常完美。
同时,在设计之初,Spring MVC 就参照了其他 MVC 框架的优缺点(包括Struts),所以用起来非常爽。因此,在 MVC 框架领域,Spring MVC 大有一统天下的趋势。
因此现在,很多公司,老的 Struts 项目还在维护。但新的项目开发,更多转向了Spring MVC。因此,如果你是 Java 新手,正在学习中,我的建议是:
“不要再学习 Struts 了,从 Spring MVC 开始吧!”
Hibernate
Hibernate 作为老牌的OR映射框架,功能非常强大,涵盖面非常广。但这既是它的优点,同时也成为它的“负担”,是开发人员“不能承受之重”。
Hibernate 的设计初衷,是为了最大程度的解放程序员,完全隔离数据库,实现彻底的 OR 映射。程序员甚至可以不写一行 SQL 语句,单通过配置就能实现对数据库的操作。
当然,为了实现这个目标,Hibernate 也设计的非常复杂、非常精巧。就不可避免的带来以下副作用:
- 学习成本高
- 配置复杂
- 调优困难
前两点不难理解,单说“调优困难”。
因为 Hibernate 的设计目标是彻底的 OR 映射,彻底的隔离 SQL 语句。但必然会带来一定的性能损失。大部分情况下,应用如果对性能不敏感,Hibernate 也没问题。但应用一旦对性能敏感,有SQL级别调优的需求,Hibernate 的优点反而成为缺点。
虽然 Hibernate 也支持 SQL 级别的调优,但因为框架设计的过于复杂和精巧,这就需要开发人员对 Hibernate 理解的非常透彻,这就带来了更高的学习成本。
而现在最流行的 MyBatis,作为一个“混合式”,轻量级OR映射框架,既继承了Hibernate 的优点,同时也吸取了他的教训。在支持配置的同时,又能接触SQL,从而带来了更多灵活性(包括调试、优化)。
当前,在实际开发中,Hibernate 使用的越来越少了。大家更偏爱MyBatis这种轻量级框架。所以,对后来学习者,我的建议是:
“不需要再学习 Hibernate 了,学 MyBatis 就够了。”