我曾在多个场合撰文说过,现在培训出来的企业Java开发兵团只知道使用某种框架,但完全不知道这些框架的底层原理。今天早上,在依次对三个职位的应聘者面试中,我又再次见到了这种情形。
我们的顾问公司收到了一个客户的招聘需求,要一个经验丰富并通晓SQL的Java开发人员。我们公司在这个客户那里享有非常好的声誉,于是我们从招聘代理公司要来了一批简历,开始搜寻合适的目标。
首先,关于他们的简历——每份简历都有数页,详细的描述了在各个公司干过的各种工作。每份简历上都有一个技术列表,表面上看这些都是应聘者懂得的技术。下面这个清单是一个真实的简历上记载的各种技术:
Core Java, J2EE, JSP, JDBC, Servlets, AJAX, XML, HTML, XSLT, Web Services, CSS, JavaScript, SQL, Oracle 10g, MySQL 5.0., JMS,Eclipse, Adobe Flex Builder 3.x,UML, JDBC, SVN, JUnit, VSS, Jira, HTML, DHTML, CSS, AJAX, JavaScript, XML, MXML, Action Script, Servlet, JSP, JSTL, Hibernate 3.x, Spring 2.x, IBatis, SOAP, UDDI, WSDL, Apache Axis, Web logic Server 8.x, Apache Tomcat 5.0, Struts Framework, MVC, ANT, Maven. |
相当的让人印象深刻…——对于那些从来没有面试过Java程序员的人来说。我并不想说这些应聘者在撒谎,只是这些人跟你的谈话坚持不到三分钟就会在80%的这些技术上露馅。他们可能听说过或者是试过这些技术或工具,这对于他们来说已经足够可以把它们列入简历了。那剩余的他们能说清楚的20%是什么?框架。基本上他们都会向你解释如何配置Struts或Spring,甚至如何让Spring和Hibernate通信。顺便说一句,他们全都喜欢Hibernate,因为它能让你省去了写SQL,而他们对SQL查询语言的知识知之甚少。
每当我看到简历上写满了这些Struts,Springs,Hibernates等东西,我就会这样问,“假设,你不允许使用任何框架。你要从数据库中的客户表和订单表中取出数据,把它们放到Web页面上,请详细完整的解释一下这整个过程。”对大部分人来说,让他们写出一些纯SQL将是一种致命请求…
有个人在简历上写了JQuery。我问她,“你为什么要用JQuery”…20秒钟的停顿…“我喜欢它,它很好呀!”这就是所有我能从她那挖掘出的关于JQuery的信息。
两周前,我参加了一个旧金山JavaOne大会里的一个技术主题会。Brian Goetz向我展示了一些Lambda表达式(也就是闭包)的样例代码,这个东西将在明年的Java8中出现。这是一个相当高级的语言特征,它所用的Java语法是给有勇气的人准备的。我在想,“在企业Java世界,谁会去用闭包?10%的程序员?5%?”。Java中引入这些表达式只是好玩?只因为它很酷?是因为其它函数式语言中有它?
软件开发产业正在发生变化。它将不再需要更多的程序员。它需要的是高级匠师,能够在软件出问题时配置并替换相关代码。理想情况下,你的团队中应该有一个Java高手,他能真正理解你们应用中的代码,不仅能够从模块级调整它们,并且能理解每行Java代码。这样的人多少也该知道如何写SQL外连接,知道如何纠正编译问题,等等。
典型的企业经理都希望手下拥有更多的软件开发人员。多管一些人是向上晋升的一种捷径。是这么回事。但如果你足够聪明,你应该确保你那一堆框架程序员中至少有一个是货真价实的。
我又收到了一份简历,将在明天早上10点面试。这简历看起来很眼熟。我只看了它工作过得公司和干的项目。上面其它的信息都是没用的——明天早上10点钟他自然会现出原形。
明天的更新。现在是早上10点15。又一个面试结束了。第四个错误的回答是,要想把数据传送到浏览器,一个servlet需要把数据放到HTTPSession对象属性里。在听了10分钟这样的回答后,你会认为我终止这次面试的行为很粗鲁吗?
明天的明天的更新。我给这个职位每小时的报酬上增加了5美元。偏偏这第一个面试者就扛着胜利的大旗通过了我的面试。别以为这区区5美元就能叩开栖息着有才能的程序员的奇异世界的大门!
-
起风哥8个月前#13楼假如没有了这些高级语言,让你用二进制去写个网页出来,你会怎么写?听说点赞多了,网页自动就写出来了。1
-
未知名的艺术家9个月前#12楼好文章。三年前我入门java那天就发现这个浮躁的现象,JAVA似乎为我们带来了这样的矛盾:从纯JAVA的角度真的能够理解JAVA吗?涉及重要的入口都会在一个native修饰的方法前面终止,堆和栈在java中也只是一种概念,println()为什么能在屏幕上输出东西?操作系统做了写什么东西?这句代码是如何被加载的?为什么CPU能够执行这样的代码?代码的本质是什么?代码如何控制硬件?CPU是什么东西?CPU为什么能够执行代码?它的电路图是怎样的?为了回答这个问题,我入坑嵌入式开发两年了...在写这段文字的十分钟前我刚好把我的代码通过数据线烧录到了一个开发板上,这是一个相机驱动程序,还带有人脸识别的功能,这里没有任何操作系统和函数库,只有一堆寄存器和几个存储器还有一个ARM系列的微处理器。就在一分钟前搜狗突然弹出一个脚本,不知道又是哪位js兄台写的鬼东西,也许是基于js的某些框架,重要的是:上面轮放了一个车模,车模很漂亮,皮肤白皙,很好看,天哪真好看,比摄像头程序中采集到的我孤单微微泛黄的容颜好看多了...还说近期将会在深圳举行什么车展,我一点兴趣都没有。框架的出现对企业来说是很有用的,可是对个人也许就是温水煮青蛙了。资料中说 詹姆斯.高斯林 是一位c/c++大神,他是计算机天才,而他自己并没怎么用java...1
-
dark_souls3周前#11楼看源码不是啥都看,主要看集合类的源码,相当于学习数据结构,为啥人家的写的数据结构比你写的好,你得看看原因,至于框架你会用,也许熟练JAVA开发者都会用,英语是必学的,SO你懂吧
-
喜欢IT的女子7个月前#10楼我作为HR在招聘了解底层的Java工程师,实在是对技术不好判断啊,能否指导一二呢
-
thats_it8个月前#9楼不懂底层原理的程序员不是个好程序员。知其然知其所以然。
-
panmaze1年前#8楼就像你做个开发的为什么不懂操作系统原理,cpu制作原理一样查看回复(1)
-
panmaze1年前#7楼这文章无语,感觉每个企业需要开发自己的框架一样?对绝大部分企业只需运用就可以了查看回复(4)
-
u0127629031年前#6楼我是一个菜鸟中的菜鸟,深度很难学,比方IO,线程和socket的底层大家讲的都很浅层
-
weixin_421042001年前#5楼我是一个菜鸟中的菜鸟,想问一个问题,比如最简单的“System.out.println()”这一句,我需不需要了解它的原理?那我们应该如何去学?关于框架,你不知道源码是不可能会使用的吧。。