什么是框架?

张大胖立志走上Java之路, 听了大神Bill的指点, 先学了Java SE, 把集合、线程、反射、IO、泛型、注解之类的基础知识学了一遍, 在Bill的严厉督促下,写了大量的代码。

然后开始学Web基础,什么Http, html, javascript , css , servlet, jsp , tomcat ...... 又是一大堆知识点。 他在网上找了一个小网站, 自己模拟着做了一下, 虽然不是专业美工, 界面惨不忍睹, 但总算是把功能模仿了七七八八, 很有成就感。

大胖拿去给Bill 看了, Bill 夸奖道: “嗯,功能实现的还可以, 没有用任何框架能做成这样子, 很不错。 ”

大胖说: “框架? 什么是框架?”

Bill 愣了一下: “ 你还突然把我给问住了, 我们整天开口框架,闭口框架, 现在让我给框架下个定义, 我还真说不出来, 让我想想。 ”

Bill 闭目养神, 大胖虔诚等待。

不到一炷香功夫, Bill睁开眼睛:“ 我来给你举个例子, 你不是刚刚用servlet和jsp做了小的Web项目吗, 假设有人出钱让你再做一个类似的系统,你会怎么办?”

“那我就把现在的代码复制一下, 在上面改改, 不就得了? ”

“如果有十个八个类似这样的项目呢, 难道你都通过复制粘贴来做吗?” Bill 问

“十个八个? 我还是跳楼去吧。 ”

“那你没有想想把其中重复的一些东西抽取出来, 形成可以复用的东西?”

张大胖说: “ 听你这么说,还真的有一点可以复用的东西, 比方说URL和业务代码的映射, 我经常会遇到类似这样的 url: www.xxx.com?action=login , 在后台的servlet 中我就判断, 如果action 的名称是login , 我就把userName, password 这样的参数从表单中提取出来, 执行登录的代码。 我得写很多的if else 才能支持不同的业务逻辑, 很折磨人。 有时候我就想, 要是有一种方法, 能够直接把URL和Java类直接映射起来就好了 , 这样就轻松多了!”

“没错,这是一个很好的想法, 还有吗? ” Bill 笑着问。

“嗯。。。 再比如数据验证啊,比如登录时用户名或者密码出错, 我要在浏览器端显示错误提示信息,这个也很难搞啊, 错误提示的字体、颜色、图标、位置太烦人了。”

“还有吗?”

“对了,访问数据库也是个大问题, 我写了很多的SQL, 很多的JDBC 代码, 仅仅是为了把数据从数据库取出来, 放到Java 对象中去。 你肯定知道,直接用JDBC编程得处理很多细节问题:一定要记住关闭连接了, 处理异常了 。。。等等, 不瞒你说,很多代码都是我复制粘贴的。”

“难道你不能写一个通用的类, 传入SQL,返回结果集吗? ” Bill 问道。

“那我肯定是写了, 但是把结果集变成Java 对象还有一段很长的路呢, 没啥技术含量, 纯粹体力活, 怪不得人家叫我们码农! ” 大胖愤愤的说。

Bill 说: “我刚才翻了翻你的代码, 我发现很多的地方都让人不爽啊, 比如你几乎把所有的业务逻辑都写到Servlet当中去了, 中间还掺杂者页面控制和跳转, 这么乱七八糟像意大利面条一样的代码过了一个月估计你自己都看不明白了。 ”

大胖不好意思的笑了: “不用一个月, 这刚过了一个星期我就犯晕了。”

“所以嘛, 其实你这些问题我们的前辈早就遇到了, 他们也苦苦探索, 不断寻找好的实现方式, 找到以后就把各种经验给固化下来, 称为最佳实践。

“最佳实践? 能举个例子嘛!”

“比如在Web开发中就有一个很好的实践啊,叫做MVC。 就是针对你上面的业务逻辑和页面控制混在一起提出的解决办法。 这个实践会强烈的建议你把数据模型、页面展示、页面跳转控制分开来写, 防止搅成一团。”

Bill意犹未尽, 继续举例: “再比如你说的第一个问题, 也早就有解决方案了, 可以利用XML或者Java注解来描述URL和Java 类之间的关系,你只需要声明一下, 背后的操作,都交由框架去处理了。 还有你的Java 对象和数据库表的对应关系, 也只需要声明一下,框架就可以帮你把数据取出来,填充到Java对象中去,这就极大的减轻了你的工作量。”

“Bill, 你又提到框架这个词了,可不可以这么说, 框架就像一个模板, 里边已经预置了一些公认的最佳实践,我要是想用的话, 把我项目相关的东西填充进去就可以了,是不是这样?”

“可以这么理解, 框架像个半成品, 是无法独立运行的,必须由开发人员按照它定义的规则,把项目的代码放置到指定的地方, 由框架整合起来,这才是一个完整的应用程序。”

大胖挠着头说: “那框架其实也没什么啊, 我只要理解了那些最佳实践, 掌握了它的规则,可不就学会了吗?”

“没错, 现在很多Java Web系统都是基于像SpringMVC, Hibernate, MyBatis这样的流行框架构造起来的, 框架不得不学, 但是如果只会使用框架, 只会填充代码, 那只是一个HTML填空人员。”

“那我学完了框架,可以用框架做项目了, 接下来学什么?” 大胖心里有点没底。

“你要是对Java 后端编程感兴趣, 还有很多东西啊, 用框架实现了业务只是很小一块, 还有系统架构设计, 缓存、性能、高可用性、分布式、安全、备份等很多内容啊, 你学的越多,就会发现无知的领域更多, 所谓学无止境啊!”

张大胖目视远方,沉默了。。。。。

我有一个微信公众号,经常会分享一些Java技术相关的干货。如果你喜欢我的分享,可以用微信搜索“Java团长”或者“javatuanzhang”关注。

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏我和未来有约会

Silverlight网络寻奇 at 090428

都是Silverlight做的游戏 http://www.silverarcade.com/Games Introducing Html Utilities f...

2944
来自专栏张善友的专栏

跨平台移动开发UI语言 -XAML

Xamarin.Forms 把XAML (Extensible Application Markup Language, XAML) 带进了ios,androi...

1868
来自专栏超然的博客

document.body.scrollTop与document.documentElement.scrollTop兼容

  这两天在写一个JS的网页右键菜单,在实现菜单定位的时候发现了这个问题:chrome居然不认识document.documentElement.scrollT...

902
来自专栏张善友的专栏

Caliburn Micro for Windows Phone 7

Caliburn Micro (caliburnmicro.codeplex.com) 是一个小巧但功能强大的 Caliburn (caliburn.codep...

1718
来自专栏转载gongluck的CSDN博客

cocos2dx 连连看

#include "GameLink.h" #include "CountDownBar.h" USING_NS_CC; Scene* GameLink::...

2965
来自专栏NetCore

Fluent NHibernate 之旅 导航篇

ORM大家都非常熟悉了吧,我相信也有很多朋友正在用自己或者一些公开的框架,而最常用而且强大的,非Hibernate了(Net中为NHibernate),网上的文...

1817
来自专栏静晴轩

TOP 100 大前端超棒精选列表

正值如今这信息爆炸的年代,如何能从中汲取精华,于有限时间内,成为更高效的学习者,从而在激烈的竞争中更具优势,是当下每个人或企业都该思虑的问题;先前创立的 Web...

1253
来自专栏天天

Canvas高级

1091
来自专栏GIS讲堂

Openlayers4中实现动态线效果

2342
来自专栏十月梦想

canvas简单线条的绘制

1.绘制线条之前首先进行声明线条开始绘制代码context.beginPath;说明:context是画板中获得的绘画环境上述的是cv

442

扫码关注云+社区