什么是框架?

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

相关文章

来自专栏ATYUN订阅号

Medium网友开发了一款应用程序 让学习算法和数据结构变得更有趣

Medium网友Peter Weinberg开发了一款名叫CS-Playground-React的应用程序,可以使大家更有意思、也更加轻松地学习算法和数据结构。...

3515
来自专栏BeJavaGod

以最简单的登录为例,诠释JS面向对象的简单实例

JavaScript,是前端开发人员必须会的一门技术,从JS演变出来的有很多框架,先说说几个热门的框架吧: JQuery:这个技术必须会,如果不会,那一定要会查...

3087
来自专栏程序员的诗和远方

20181007_ARTS_week15

这个写的比较杂乱,因为一开始思路就是想着比较大小,然后构造新的节点,赋值,找下一个,做成单链表。因为要比较是否是 null 以及实际值,所以比较条件写的有点复杂...

652
来自专栏Python爬虫实战

Python爬虫之六:智联招聘进阶版

运行平台: Windows Python版本: Python3.6 IDE: Sublime Text 其他工具: Chrome浏览器

821
来自专栏CDA数据分析师

电商数据分析时的excel的基本操作(吐血总结)

一般的使用Excel的工作习惯 1.保留原始文件,新建一个Sheet进行处理数据存放,或者另外COPY一份新的文档,尽量保持原始数据的原貌,因为我们都不知道啥时...

23810
来自专栏小狼的世界

是什么让我们爱上Javascript

    过去,人们对于Javascript一直报着轻视的态度,人们认为它又慢又容易出错,而且在不同浏览器中解释也不一样,但是现在,Javascript确确实实的...

963
来自专栏企鹅号快讯

人工智能的语言-PYTHON

1989年的圣诞节33岁的荷兰人Guido van Rossum很是无聊,看完《Monty Python飞行马戏团》后,思绪便信马由缰地乱跑起来,脑子有一个声音...

19810
来自专栏何俊林

我在创业公司的开发经验总结

754
来自专栏MixLab科技+设计实验室

如何用代码控制浏览器下载知乎大v的粉丝数据?

欢迎用户在后台留言需解答的问题, mixlab 将会不定期的从中选择提供解决方案。同时 mixlab 微信群已经汇集了机器学习、自然语言处理、前端、后端、产品经...

853
来自专栏Python专栏

Python | 爬虫爬取智联招聘(进阶版)

运行平台: Windows Python版本: Python3.6 IDE: Sublime Text 其他工具: Chrome浏览器

331

扫码关注云+社区