什么是框架?

张大胖立志走上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 条评论
登录 后参与评论

相关文章

来自专栏take time, save time

三十天学不会TCP,UDP/IP网络编程-TraceRoute的哲学

新年快乐,继续来部分粘贴复制我的这一系列文章啦,如果对和程序员有关的计算机网络知识,和对计算机网络方面的编程有兴趣,欢迎去gitbook(https://www...

3749
来自专栏Samego开发资源

简洁的UDP协议通讯 | PHP&&C | socket

2588
来自专栏惨绿少年

网络基础一 交换机 路由器 OSI7层模型

第1章 网络基础 1.1 网络的出现 解决计算机通讯的需求 实现计算机信息可以传递 1.2 主机之间实现通讯基本要求(三要素) ①. 需要在两台主机之间建...

2160
来自专栏栗霖积跬步之旅

第一章计算机网络和因特网-day01

什么是因特网: 其一:构成因特网的基本硬件与软件。 其二:为分布式应用提供服务的联网基础设施。 终端机器称为主机( host ) 或者端系统( end syst...

3235
来自专栏互联网技术杂谈

udp的若干问题

参考链接:https://blog.csdn.net/dog250/article/details/6896949

44910
来自专栏宋凯伦的技术小栈

Quartz Cron表达式的二三事

最近在解决产品上的一个需求,就是定期生成报告(Report),我们叫做Scheduled Report。 原理:UI获取用户输入的时间信息,后台使用Spring...

2137
来自专栏take time, save time

三十天学不会TCP,UDP/IP网络编程 - 绅士的开始

经过了过年的忙碌和年初的懈怠一切的日子,我又开始重新更新了~这是最新的一篇~完整版可以去gitbook(https://www.gitbook.com/@rog...

35910
来自专栏乐享123

TCP/IP Illustrated Note1

1304
来自专栏互联网技术栈

OSI七层模型及对应协议

为数据链路层提供物理连接,在其上串行传送比特流,即所传送数据的单位是比特。此外,该层中还具有确定连接设备的电气特性和物理特性等功能。

2783
来自专栏SDNLAB

Openflow细节理解之—Buffer_id篇

OpenFlow消息中buffer_Id是什么? Openflow中buffer_id分别在三类消息中定义,并且起到的作用均是不同的。 ✔ Packetin消息...

3545

扫码关注云+社区