Mike Hadlow是一位资深软件开发者,同时也是EasyNetQ与Suteki Shop的作者,喜爱历史与科技,是一个技术极客。近日,Mike就程序员工作效率、工作表现以及工作成果等主题撰写了一篇博客,谈到了我们该如何看待程序员到底是在努力工作还是在偷懒这个问题。
如果人们从事的是体力劳动,那么我们就很容易能够看出他们工作的努力程度。你会直观、清楚地看到他们频繁移动的步伐,流下的汗珠。还会看到他们工作的成果:逐渐升起的砖墙,地上的洞变得越来越深,等等。观察到并奖励努力工作的人是人类的一种很基本的天性,这也是我们觉得忍耐力运动令人着迷的原因之一。不过对于管理技术创造性的员工来说,这种对努力的体力劳动天然的欣赏之情就会出现问题。高效的知识工作者常常看起来并不是那么努力工作。
回到2004年,那时我还是一名初级开发者,工作在一个大型团队中,主要从事有线电视公司的账单与供应系统。就像所有的大型系统一样,这个系统由大量相对比较独立的组件构成,不同的小组负责不同的组件开发工作。模拟电视与数字电视供应系统几乎是完全分开的,由两个不同的小组分别进行开发。
模拟电视团队决定根据Microsoft Biztalk的一个早期版本来构建他们的系统。团队有4个人以及一个来自于微软的团队共同开发并运行这个系统。他们看起来工作非常努力,常常工作到深夜,周末也在加班加点。当遇到生产问题时,团队的每个人都会放下手头的工作,围拢在一起,提供各种建议和意见,以及如何修复问题的见解。你会看到,这个团队中的每个人都有很强的团队凝聚力,而且他们工作都非常努力。
数字电视供应系统则大相径庭。系统的代码几乎是由一个家伙搞定的,我们暂且称这个家伙为Dave吧。我是团队的一名初级维护工程师。一开始,我在理解代码时遇到了很多麻烦。程序中并没有长长的过程语句,相反有大量的小体积类和方法,每个方法的代码也只有寥寥数行而已。我有几个同事抱怨Dave将事情搞得过于复杂了。不过Dave却建议我应该阅读几本关于面向对象编程的图书。他教会了我设计模式、SOLID原则以及单元测试等知识。很快,他所编写的代码开始变得具有现实意义了,随着我不断加深对代码的理解,我也越来越发现它优雅的设计。代码在产品中没有出现问题,只是一直在默默地工作。要想对代码做出修改也是轻而易举的事情,因此实现新的特性简直是手到擒来。单元测试意味着进入到生产系统中的Bug数量变得微乎其微。
结果就是我们这个团队看起来工作不那么努力。我每天下午5:30下班,周末也从来不用工作,我们也不必围聚在一起猜测到底是什么原因导致了生产系统的问题。从外人的角度来看,我们所从事的工作肯定要比模拟电视团队的简单得多。事实上,二者的需求非常相像,只是我们开发出了设计更好的软件、提供了更好的支持基础设施,特别是单元测试。
管理团队宣布要根据绩效给予员工奖励。轮到老板与我谈话时,他说公平的做法是对那些努力工作的员工给予奖励,工作越努力,奖励力度越大,我们的团队看起来对公司并不那么在意,更无法与那些放弃晚间与周末时间的英雄相提并论。
这家有线电视公司有一点与众不同,你可以直接比较好的软件设计与差的软件设计之间的差别,还可以对团队行为进行比较。大多数组织者都并没有提供这一比较。我们很难说某个员工是不是通宵达旦地工作,甚至周末时间也在工作,频繁充当救火队员的角色,这种做法是不是就是复杂软件系统必须要做的呢。除非你可以让几个互相竞争的团队解决同一问题,否则你永远也没法直接比较他们工作上的差别。相反,对于那个坐在角落里,朝九晚五工作的家伙有可能花了很多时间在上网呢?也许他非常善于编写稳定、可靠的代码,也许他的工作要比其他人的简单。对于偶尔过来检查的管理者来说,他们会觉得第一种人工作很努力,第二种人则不是这样。努力工作就很好,偷懒就很不好,真的是这样么?
我的看法是表面上的努力工作常常是失败的信号。高压力、频繁中断的环境常常无法开发出好的软件。长时间的工作也不是一种正确的做法。有时,解决难题最好的方式可能是不再思考这个问题,出去走走,或是睡个好觉,让你的潜意识来解决问题。我最喜欢的一本书是G. H. Hardy所编写的A Mathematician’s Apology,他是20世纪英国的一位杰出数学家。这本书描绘了他每天的工作:上午工作4个小时,下午观看板球比赛。他说对于复杂的脑力工作来说,一天工作4个小时以上是完全没有意义且生产力低下的方式。
我想对管理者说的是,以结果为导向,根据员工工作的成果,根据可运行的软件为导向,不要被人们表面上的努力工作所蒙蔽。另外,最好不要与你的开发者坐在一起,你会得到更好的结果,不受传统、直觉判断所影响的好结果。远程工作的好处是非常多的,你只能以输出来衡量员工的工作情况,而不是看他们是不是每天端坐8小时盯着IDE在看为标准,或是聚集在一起提出自己的见解为衡量的准则。
有读者评论说,文章写的很实在,有时真的很难说服同事设计的简单性与恰当使用OO原则所带来的好处。我就看到有的人以编写复杂代码并工作到深夜为傲。
还有读者说,我曾经与一个家伙共事过,他说“第一次就将事情做对的困难之处在于没有人认识到事情会有多么复杂”。几年过去了,我发现这句话非常正确。我现在都会在项目开始前进行大量的提前设计。这常常会让执行变得非常平滑,不过可能会让其他人觉得这件事挺简单的。
相关推荐
在IT行业中,程序员是至关重要的角色,他们负责创建和维护软件、应用程序以及各种技术解决方案。那么,什么样的人适合成为程序员呢?...通过这样的自我修养和努力,才能在IT行业中不断成长,成为一名真正优秀的程序员。
不大,所以资本不会驱动这个变革。研发生产一个像人手那么的灵活的厨师...程序员工作效率提高了,只会导致程序员的工作任务增多,而不会变成程序员的数量减少了,为什么?程序员都知道的,因为新需求总是会源源不断的
工作日志是程序员日常工作中不可或缺的一部分,它可以帮助程序员更好地管理自己的时间、提高工作效率、记录工作进度、总结工作经验等。本文档是一个程序员工作日志示例,旨在帮助程序员更好地管理自己的工作,提高...
面试中,有些有多年工作经验的程序员可能会因为题目过于基础而感到困惑,这反而暴露出他们可能在日常工作中过于依赖现有的框架和解决方案,而缺乏自我挑战和学习新知识的动力。软件开发行业日新月异,停滞不前意味着...
程序员在工作中被打扰会面临严重的影响,这是一个在软件开发领域公认的问题。程序员在解决复杂的编程问题或者进行深度编码工作时,他们的大脑会进入一种被称为“心流”的状态。心流状态是一种极度专注的心理状态,在...
标题 "你是合格的程序员吗?—合格程序员应该具备的12种能力" 指向了一个讨论合格程序员所需技能的主题。在这个行业中,成为一个优秀的程序员不仅仅是掌握编程语言那么简单,还需要一系列综合能力。以下是对这些能力...
### 做一个会“偷懒”的程序员 ...综上所述,“偷懒”的程序员并不是指懒惰不负责,而是在保证工作质量和进度的前提下寻找更加高效的方法完成任务。只有这样才能够在日益竞争激烈的IT行业中立于不败之地。
刚刚走出就业的程序员,技术是刚刚起步的基点。那下面我们就聊一聊有关技术的东西。...你又是哪一类的程序员?“菜鸟”程序员和“大神”程序员差在哪里?真是差在技术上了吗?那不是差在技术上那差在了哪里?
2. 团队协作:在团队协作方面,前端程序员学习了团队协作的重要性,明白了人强团则强,人弱团则削的道理,通过团队协作,前端程序员成长了很多,增强了自己的业务素质和工作能力。 3. 个人成长:在个人成长方面,...
如何成为优秀的程序员?请看程序员的10层楼
程序员在囧途,程序员的生活、工作历程和发展方向
* 程序员转正述职报告的主要内容包括职业规划、职业发展和工作总结 * 程序员转正述职报告的目的是为了总结试用期的工作经验和学习体验,并对未来的职业发展进行规划 二、java 开发语言和环境 * java 开发语言是...
程序员如何提高工作效率
IT 项目交接文档概要是程序员在项目交接过程中的重要文件,它对项目的开发、测试和维护起着至关重要的作用。本文档概要将对程序员项目交接文档的主要内容进行概要介绍。 人事模块是程序员项目交接文档的重要组成...
程序员的九重境界,你是第几重?看看这位高手写的有关程序员的境界。从第一层到达最高层,你是第几层?请进来看看。程序员 java 境界 php SSH struts
总的来说,程序员的自我评价总结反映了他们在技术、沟通、团队协作、个人发展和职业规划等方面的努力和成长。在不断变化的IT行业中,持续学习、适应环境、解决问题和保持热情是程序员成功的关键。同时,良好的团队...
走过的路,回忆起来是那么曲折,把自己的一些心得体会分享给程序员兄弟姐妹们,虽然时代在变化,但是很可能你也会走我已经做过的10年的路程,有些心得体会你可以借鉴一下,觉得说得有道理的你就接纳,觉得说得没道理...
个人独家收藏,小编愿意在这里和大家分享程序员的工作经验。 一位程序员工作10年总结的13个忠告+一名程序员的十年工作经历+程序员(工作十几年)的创业血泪史,万字长文,与君共勉!+程序员工作几年的一些感悟+...
最真实的草根程序员的创业之路】《程序员在囧途》通过幽默有趣的故事,潜移默化地把技术开发、程序员求职、项目管理、创业思路、软件行业商业运作、职业转型、自我修养等各个方面融合在一起,让读者在开心地读故事的...