框架会使程序员变笨吗?

admin 13年前
     本文是从    <a href="/misc/goto?guid=4958189207922047215">Are frameworks making developers dumb?</a> 这篇文章翻译而来。    <p> 上周,我做了几次面试,要招几名有5年工作经验的高级Java开发人员。但当面试结束后,我感觉到,各种框架(frameworks)使开发变得容易,但同时,也使程序员变笨。</p>    <p> 每个人都会在他们的简历中罗列出几乎所有的新框架,他们能“熟练的使用Spring,Hibernate,Web Services等”。</p>    <p> 下面是面试的过程。</p>    <p> <strong>我:</strong> 你在你最近的项目中使用了Spring。使用Spring有什么好处?</p>    <p> <strong>应试者:</strong> 我们使用XML配置出bean信息,Spring能够帮我们实例化这些bean,供我们使用。</p>    <p> <strong>我:</strong>如果Spring只是用来创建对象,那我们干嘛要用它?我们可以直接使用“new”来实例化各种依赖关系。为什么我们还要在XML里配置类的名字、要从Spring里取对象?</p>    <p> <strong>应试者:</strong>如果改天我们又需要对接口做另外一种实现,我们开发出实现后,更改一下XML配置,就能使用我们的新实现了。我们不需要去修改Java类和重新编译它们。</p>    <p> <strong>我:</strong>可是既然你写出了新的Java类,你必然要重新编译你的项目。</p>    <p> 至于XML里的变化,99%的时间里你的XML都是打包在war 或 ear 文件里的。</p>    <p> 所以,你只需要运行一下ant脚本,把你所有的变更都包在war文件里就行了。你的“如果使用XML就不需要编译”的观点是站不住脚的。</p>    <p> <strong>应试者:</strong>唔,但依赖注入的设计模式建议采用这种做法。</p>    <p> <strong>我:</strong>好吧。我们就先聊到这。人力资源部会给你打电话的。 </p>    <p> 面试另外一个家伙:</p>    <p> <strong>我:</strong>你能描述一下你最近开发的项目、以及使用到的技术吗?</p>    <p> <strong>应试者:</strong> 那是个XYZ系统,我们使用了Spring,Hibernate,REST WebServices。</p>    <p> <strong>我:</strong>那好。你能解释一下RESTful吗?</p>    <p> <strong>应试者:</strong>我们使用@RequestMapping(value=”/url”, method=”POST”)来开发RESTful应用。我们还使用了PUT,DELETE方法。</p>    <p> <strong>我:</strong>哦,那RESTful个什么概念?</p>    <p> <strong>应试者: </strong>我不是说了吗,如果你使用 @RequestMapping(value=”/url”, method=”POST”),你就是在开发RESTful应用。</p>    <p> <strong>我:</strong>哦,你对Hibernate如何?</p>    <p> <strong>应试者:</strong>我这两年一直在使用Hibernate。我对Hibernate很熟悉。</p>    <p> <strong>我:</strong>跟JDBC比起来,Hibernate有什么优势?</p>    <p> <strong>应试者:</strong>使用Hibernate,我们不需要写任何跟数据库交互的东西,Hibernate会帮我们处理这些。</p>    <p> <strong>我:</strong>那Hibernate怎么能知道你的项目需要如何的存取?</p>    <p> <strong>应试者:</strong>如果我们使用了Hibernate,它会帮我们完成存储,更新,取数据等数据库操作。</p>    <p> <strong>我:</strong>哦,哦。你在业余时间会读一些技术相关的博客吗?</p>    <p> <strong>应试者:</strong>当然,我对Hibernate的深入掌握就是这样学会的。</p>    <p> <strong>我:</strong>非常好,很高兴见到你。我们的人力资源部会给你打电话的。 </p>    <p> 面试过程就这样…</p>    <p> 我绝对相信各种框架会提高程序员的工作效率。但程序员也应该努力去了解这些框架是如何工作的。你并不需要理解各种框架的所有内部工作原理。如果你非常的擅长Servlets和JSP,那你就很容易理解诸如Struts,Spring MVC等Java Web框架。如果你不了解这些基础知识,很显然,所有你的回答只能是“框架/标记/XML帮我们做了这些”。</p>    <p> 我强烈建议所有刚开始职业生涯的Java程序员都要认真学习Java核心,Servlets,JSP知识。只有这样你才能正确的理解各种框架的工作原理。<br /> <br /> 来自: <a id="link_source2" href="/misc/goto?guid=4958189208656139387" target="_blank">外刊IT评论</a><br /> </p>