`

怎么样才是好的程序员

阅读更多

转载自:http://wangyuanzju.blog.163.com/blog/static/1302920091130104953863/

要判断一个程序员是不是好的程序员,主要看他写的代码,因为程序员最重要的事是写代码。

即便不去理解代码的意图,只要看一眼,好的程序员写的代码与差的程序员写的代码基本上就可以看出来。好的程序员写的代码,整洁而规范,视觉上自然有一种美感 。空白错落有致,注释恰到好处,命名和排版遵守统一的规范。差的程序员写的代码则经常出现过长的函数,前后不一致的命名方式和排版,过深的嵌套结构,非常复杂的表达式,随处可见的数字等毛病。

再去粗粗阅读,对好的程序员还是差的程序员就会更有把握。好的程序员写的代码,有一种精心雕琢而成的一致性 。好的程序员一致会遵守统一的命名方式,如camelCase,而差的程序员的变量命名时不时的就会偏离统一规范。好的程序员的代码中拼写错误几乎不可见,而差的程序员的拼写错误要多得多。好的程序员对于同一类动作,不会忽而用这个动词,忽而又用那个同义词,如add/insert混用。好的程序员采用一致的简写规则,差的程序员则时而不简写,时而简写。好的程序员会很注意名称中形容词与名词谁在前谁在后,而差的程序员没有规则,时而在前时而在后。好的程序员很少会写出大段大段的重复代码,差的程序员却经常搞不定重复代码,他们难以将重复的代码抽取出一个统一的概念进行重用。好的程序员对于对外的API会注重注释与代码的一致性,差的程序员经常注释中的参数名称与函数定义都不一致。好的程序员很少会留下被注释掉的或用#if 0括起的垃圾代码,他们意志坚决,代码有用就要,没用就不要,差的程序员则不一样,他们经常不确信一段代码是否真的需要,他们缺乏保持代码整洁的习惯,因此他们让垃圾代码留着。

如上,即便你不懂他所用的语言,不却关心程序的逻辑,对好的程序员还是差的程序员就能做到八九不离十的判断 。程序的好坏几乎总是取决于它们是否“漂亮”,不“漂亮”而好的程序,除了C++ STL源码,我再也没见过(如果你稍仔细看,STL的源码虽然不够“漂亮”,但仍然满足这里提出的一致性原则)。而又好又“漂亮”的代码则随处可见,如Linux Kernel,InnoDB,JDK,JUnit等等。

如果再仔细阅读,就能更准确。好的程序员写的代码,好似浑然天成,简单而直白 。函数通常较短小,函数的名称准确的反映函数要完成的工作。逻辑简单而自然,让你读的时候由衷的发出“啊,就应该是这样”的感叹,而差的程序员的代码经常让你发出“怎么是这样?这是再干什么呀?”的疑问。好的程序员会在紧要关头加以画龙点睛般的注释,差的程序员要么没注释,要么注释只是代码的重复,纯粹是废话,更差的是注释是错的,是误导。

好的程序员未必是“语言律师”,即那种非常清楚的了解语言的各个细节,在编程时到处使用的家伙。好的程序员也不常“炫技”,在代码中精心构造一些独具匠心的片断,他们偶而会,但大多数时候总是用直白的语言来表述。

从代码也可以看出一个程序员的团队协作精神 。注意团队合作的程序员,会严格按照团队规范写代码,而风格与团队规范不一致的程序员则很可能欠缺团队精神。注意团队合作的程序员会注意给模块的对外接口加以重要的说明,如前置条件、后置条件、参数能否是NULL等等,不注意团队合作的程序员懒于处理这些细节。

好的程序员与差的程序员的生产力差别巨大,项目的周期越长,项目越复杂,项目对质量的要求越高,好的程序员的价值就越大。好的程序员与差的程序员,管理成本也差别巨大,好的程序员只需要与他共同确定设计,代码可以不看,差的程序员的代码经常需要经过多次review,且仍有可能达不到理想的质量。

要成为好的程序员,首先要树立要成为好的程序员的志向,再勤加练习,天长日久,就会越来越好,这些人不怕老。没有志向永远成不了好的程序员,这些人若不在老去之前成为经理就会变成废人。

通过两个小时的笔试和半个小时的面试对于判断程序员来说是不够的。通过笔试与面试,你可以判断一个程序员是否具备算法与数据结构等基础知识,可以判断他对编程语言的特性是否掌握,可以判断他对技术是否关注,然而要知道他能否真的能很好的完成工作,不写代码是不够的。

那些显得对技术充满热情的,未必是好的程序员。这些人可能非常乐意从事有新意的工作,但后续的编码、测试、调试、文案工作则可能让他们感到厌烦。他们可能会提出好的创意,但却经常不能够有始有终的将其完成。公司不需要多少这样的人。

因此招聘的方式需要改善。招聘是最重要的,因为进来后就难以出去,即便是试用。转正条件白纸黑字写的很清楚,只要合格就可以转正,要达到合格并不是很困难。今年部门里进了很多新人,并不是人人都很优秀,但确实也都合格,自然也应该转正。

改善招聘的方法,就是让他写程序,可以出两道题,一道让他写程序,一道让他重构一个已有的较长的程序,一天之内完成。假使可以考他半个月,那么重构是不太需要的,但一天的时间太短,通过重构可以考察阅读并理解代码,并通过重构“化腐朽为神奇”的能力。那些不愿意写别人的代码,不愿意接受别人的代码,经常要重来一遍的人是不理想的。

今年有两个人采用了类似的方法。有一位简历很优秀的人,做了两道编程题被拒了,有一位简历及面试一般的人,通过编程测试,录用了。我感觉比单纯的笔试与面试要准确。

分享到:
评论

相关推荐

    什么样的人适合做程序员?程序员应该具有什么样的素质程序员四大禁忌

    程序员应该具有下列素质: ①耐得住寂寞,静不下心来的人做不得。 ②禁得起熬夜,一个程序不是一天两就能... ⑤最后,如果能达到这一点要求是最好的:愿与电脑长相厮守。 程序员四大禁忌: 一忌:轻易言败,没有自信

    好的程序员如何写代码

    要判断一个程序员是不是好的程序员,主要看他写的代码,因为程序员最重要的事是写代码。 即便不去理解代码的意图,只要看一眼,好的程序员写的代码与差的程序员写的代码基本上就可以看出来。好的程序员写的代码,...

    程序员转正述职报告 程序员转正述职工作规划.docx

    * 程序员转正述职报告中提到通过学习和掌握 java 开发技术,能够更好地融入公司的开发团队 三、CBP 产品框架 * CBP 产品框架是程序员转正述职报告中提到的主要技术之一 * 程序员转正述职报告中提到熟悉 CBP 产品...

    程序员技巧收集助手-程序员的好帮手

    程序员技巧收集助手 适合开发人员收集积累经验

    这是一个很好的程序员

    程序是个好程序员,但是这要看是否有用才行呀,你说是不是的

    程序员七夕告白源码

    精美的网页加上动听的音乐效果是程序员七夕告白的绝佳神器。里面包含了十三个源代码。第一个是计算你和另一半在一起的时间。只需要改动源码里面的起始时间就可以实现你想要的结果。怎么改动起始时间和怎么将音乐改成...

    程序员的呐喊,完整扫描版

    强弱类型语言到底哪个更好?敏捷真的靠谱吗?程序员要不要懂数学等。另外,他还谈到了很多大公司的理念,比如亚马逊做平台为什么那么成功等。最后,《程序员的呐喊》还收录了他写的Google面试攻略,这篇文章可以说为...

    程序员的鄙视李安

    对于程序员而言,语言之争永无止境,php是最好的语言。

    程序员的十大无奈

    1、有人曾说,做程序员的人,都是疯子,做长了往往入戏太深,成天与代码打交道,话都很少说,所以评论程序员们都是以后连妞都泡不到的人,我听后,我可以这样说,泡妞好比一个方法,他人是学习方法,而程序员呢,是...

    雷军 我的十年程序员生涯.doc

    如果你的程序写得好,你就可以和电脑处好关系,可以指挥电脑干你想干的事。 6. 编程的感受:雷军认为,编程人是活在自己想象的王国里。你可以想象到电脑里细微到每一个字节、每一个比特的东西。 7. 程序员生涯:...

    程序员的数学4:图论入门.pptx

    "程序员的数学4:图论入门" 本书《程序员的数学4:图论入门》是一本面向程序员群体的数学读物,旨在介绍图论的基本概念...这本书不仅可以提高程序员的数学素养,还可以帮助程序员更好地理解和应用图论来解决实际问题。

    程序员最好的SQL编辑助手

    程序员可以应用它更容易编辑数据库内容和修改内容

    程序员面试面试中的优缺点.pdf,这是一份不错的文件

    "程序员面试面试中的优缺点.pdf" 本文档讨论了程序员面试中的优缺点,主要从经验、基础和性格三个方面进行了分析。作者认为,经验是最重要的因素,因为它可以说明一个人的综合能力。面试官应该花更多的时间听面试者...

    高级程序员的45个好习惯

    高级程序员的45个好习惯,很多很经典的习惯有助于你的开发之路

    《程序员》2011年08期

    总结而言,优秀的程序员通常有一下特点: 对技术充满激情 将编程作为一种爱好 如果你允许会滔滔不绝地跟你谈论技术 有过个人的开发经历(与4意思相同) 坚持认为某种技术最好 如果让他用他认为不好的技术他会非常...

    程序员面试评语-优秀范文 (14页).pdf,这是一份不错的文件

    由此可见,本文档为一份面试评语的范文,旨在帮助程序员更好地准备面试和工作总结。 二、标签 本文档的标签为“文档”,表明该文档为一份 Word 文档,旨在提供程序员面试评语的优秀范文。 三、部分内容 本文档的...

    程序员述职报告5篇.docx

    asp.net的实现模型可以帮助程序员更好地理解asp.net的机制和方法。 管理 在管理方面,程序员需要具备良好的领导能力和团队管理能力,包括团队建设、项目管理、人力资源管理等。程序员需要了解如何管理团队、如何...

    程序员的sql经典以及源码

    这是一本为程序员写的sql书籍,抛弃了很多数据库管理知识,专注于sql知识,程序员读了对sql进阶有很好帮助,如果你对sql还不是很自信,而又有一定的sql基础,那么,这本sql书籍无疑是你最好的选择。 我看了,很不错...

    最新程序员写的辞职信程序员辞职申请书WORD文档模板.docx

    这个模板为程序员提供了一个辞职申请书的范文,帮助他们更好地表达辞职的意图和感谢公司的栽培。同时,这个模板还提醒用户需要根据自身实际情况进行增删,并且需要校订合同的内容,以免损失自己的利益。 知识点: ...

Global site tag (gtag.js) - Google Analytics