`

技术总监谈好的程序员如何写代码

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  本文来自风轻扬的博客,原文标题为《怎么样才是好的程序员》。
分享到:
评论

相关推荐

    从程序员到技术总监,分享10年开发经验

    事实上,经过十年的开发经验,我可以告诉你,如何从程序员到技术总监,并分享我的经验。 首先,我们需要明确入行的目的。很多人选择 IT 行业是因为收入高,容易找到工作,但这只是一个表面的原因。如果你只是抱着...

    技术总监岗位绩效考核表版.pdf

    在当今快速发展的科技行业中,技术总监作为核心管理层的关键角色,其工作表现的评估显得尤为重要。为了确保技术总监能够有效地管理技术团队,实现公司的技术目标,制定详尽且合理的绩效考核表是必不可少的管理工具。...

    微信技术总监分享架构设计高清完整PDF版

    ### 微信技术总监分享架构设计的核心知识点 #### 一、微信之道——至简 - **背景介绍**:微信作为一款现象级应用,其成功离不开其背后强大的技术支撑与先进的设计理念。微信技术总监周颢在腾讯大讲堂的演讲中分享...

    程序员道路的十个层次

    他们能够根据需求写出功能完整的代码,但往往依赖于模板和教程,对于代码的优化和设计模式的理解尚浅。 第三层:熟练工 熟练工具备一定的项目经验,能独立解决常见问题,对常用算法和数据结构有一定了解。他们开始...

    程序员怎么选择发展方向

    成为**技术总监**是许多程序员的梦想。这条路径通常需要从初级程序员做起,逐步成长为项目经理、开发经理,最终晋升为技术总监甚至更高职位。技术总监不仅需要对新技术保持敏感度,还要具备出色的管理能力。这条路径...

    浅谈Android移动开发程序员的职业发展之路

    ### 浅谈Android移动开发程序员的职业发展之路 随着信息技术的快速发展与智能手机的普及,移动应用开发成为了一个备受关注的领域,而Android作为全球最大的移动操作系统之一,其开发人员的需求量也在逐年攀升。本文...

    2022年全国地区技术总监职位薪酬调查报告.pdf

    《2022年全国地区技术总监职位薪酬调查报告》揭示了中国技术总监这一关键职位在不同地域、企业类型下的薪资分布情况。这份报告对于理解技术行业高层次管理者的收入水平,以及不同背景企业间的薪酬差异具有重要参考...

    谈谈程序员以后的出路

    标题中的“程序员以后的出路”是指程序员在职业生涯中可能的发展路径和策略,这不仅关乎技术提升,也涉及职业规划和转换。描述中提到,当程序员面临困惑时,有两个主要选择:一是成为工作环境中最优秀的人,二是通过...

    微信技术总监谈架构:微信之道——大道至简

    ### 微信技术总监谈架构:微信之道——大道至简 #### 一、微信之道:大道至简 在“微信之道——大道至简”的分享中,微信技术总监周颢(Harvey Zhou)深入剖析了微信如何通过简洁的设计理念来应对移动互联网时代的...

    某公司技术总监职务说明书.doc

    【技术总监职务说明书】 在IT行业中,技术总监是企业中至关重要的角色,他们负责制定并实施公司的技术策略,确保企业在技术领域保持领先地位。本职务说明书详细阐述了技术总监的职责、权限、沟通协调以及岗位资格...

    漫谈程序员职场修炼.pdf

    纯技术路线的程序员,往往专注于技术的深化与精进,从初级工程师一路攀升至架构师,甚至技术总监等高级职位。技术管理路线的程序员,则是在积累了一定的技术资本后,选择转向技术管理岗位,比如担任技术经理、CTO等...

    2022年龙岩地区信息技术总监职位薪酬调查报告.pdf

    《2022年龙岩地区信息技术总监职位薪酬调查报告》是针对该地区信息技术领域高层管理岗位薪酬状况的专业分析。报告旨在为相关企业和个人提供准确的薪酬参考数据,以促进人才市场的健康发展和优化人力资源配置。 在...

    技术总监个人工作述职报告范文大全.doc

    【技术总监个人工作述职报告】 技术总监作为企业技术团队的核心领导者,其工作职责涉及技术规划、项目管理、团队建设等多个方面。以下是对技术总监过去一年工作的详细总结和新一年的工作展望: 1. **前期工作与...

    技术总监求职简历自我评价.doc

    技术总监求职简历自我评价 这是一份技术总监的求职简历自我评价,旨在...这份自我评价可以作为技术总监的求职简历,用于展示自己的技术能力和管理经验,帮助技术总监更好地展示自己的实力,拓展自己的职业发展空间。

    架构师、技术总监、CTO职位区别.doc

    当团队规模扩大,产品线增多时,技术总监需要组建平台研发部门,建立公共技术平台以支持各产品线的开发。此外,技术总监通过技术和管理手段,协调各产品线之间的合作,确保团队的生产质量和效率。他们负责团队的组织...

    技术总监述职报告ppt

    ### 技术总监的职责与能力 1. **执行力**:确保技术团队能够按时按质完成既定的技术目标。 2. **感召力**:领导并激励团队成员发挥最大潜能。 3. **创新力**:推动技术创新,探索新技术的应用场景。 4. **决策力**...

    技术总监简历模板.pdf

    4. 技术能力:技术总监的技术能力包括网络工程师职业技能、弱电系统集成、网络电话等技术专长,展示其在技术总监岗位上的技术能力和经验。 5. 项目经验:技术总监的项目经验包括电信类业务代理、弱电系统集成、网络...

    程序员成长的十层楼!!!

    程序员的成长之路,就好比攀登一座十层的高楼,每上一层,视野便更加开阔,技术也更上一层楼。而今,我们将详细探讨这座程序员成长之楼的每一层,每一层都是一个重要的里程碑,标记着技术能力的提升和职业素养的升华...

    技术总监岗位职责版.docx

    作为企业信息技术部门的领军人物,技术总监肩负着推动技术发展、维护企业技术标准、确保安全生产等多重职责。本篇《技术总监岗位职责详解》将深入剖析技术总监在企业运营中的职责与作用,以及他们在日常工作中应如何...

Global site tag (gtag.js) - Google Analytics