你的程序员是在努力工作还是在偷懒?

标签: 程序员 工作 | 发表时间:2013-12-22 23:30 | 作者:ricohzhanglong
出处:http://blog.csdn.net

本文来源于我在InfoQ中文站原创的文章,原文地址是: http://www.infoq.com/cn/news/2013/12/are-your-programmers-working


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原则所带来的好处。我就看到有的人以编写复杂代码并工作到深夜为傲。

还有读者说,我曾经与一个家伙共事过,他说“第一次就将事情做对的困难之处在于没有人认识到事情会有多么复杂”。几年过去了,我发现这句话非常正确。我现在都会在项目开始前进行大量的提前设计。这常常会让执行变得非常平滑,不过可能会让其他人觉得这件事挺简单的。

作者:ricohzhanglong 发表于2013-12-22 15:30:15 原文链接
阅读:109 评论:0 查看评论

相关 [程序员 工作] 推荐:

为什么美国程序员工作比中国程序员工作轻松、加班少?

- -
美国程序员工作比中国程序员工作轻松、加班少总体来说是事实,但都归结到美国程序员效率更高,制度更好之类就过于片面了. 我觉得主要原因在于别的一些地方,例如加班的边际效用,程序员的生活习惯. 背景:我在 baidu(北京)和 amazon(湾区)都干过,微软研究院(北京)和 google 研究院(湾区)也实习过,因为目前做云计算和开源,所以也接触过很多公司.

程序员的工作环境与效率

- - 博客园_新闻
很赞同《Joel on Software》中 Bionic Office 一文所说,办公环境需要比大部分员工的家中环境更舒适. 否则老板只能招聘哪些还住在简陋公寓的员工,他们才有可能下班后情愿留在办公室继续工作. 我认为程序员的办公环境的几个条件. 程序员的办公桌最好可以并排坐下 2 人,以便 pair programming 或者 code review.

Java程序员在Google是如何工作的

- - ImportNew
在 Quora看到一个有意思的问题, Working at Google: What is it like to be a Java programmer at Google?,笔者对原文做了简单的编译,虽不能至,心向往之. 严格遵守“Google Style”,这份“Google Style”会有详细的文档清楚地告诉你如何编码(一开始你会觉得很痛苦,但是以后你会享受它带来的好处).

你的程序员是在努力工作还是在偷懒?

- - CSDN博客研发管理推荐文章
本文来源于我在InfoQ中文站原创的文章,原文地址是:. Mike Hadlow是一位资深软件开发者,同时也是EasyNetQ与Suteki Shop的作者,喜爱历史与科技,是一个技术极客. 近日,Mike就程序员工作效率、工作表现以及工作成果等主题撰写了一篇 博客,谈到了我们该如何看待程序员到底是在努力工作还是在偷懒这个问题.

程序员高效率工作工具推荐(必备工具)

- - CSDN博客研发管理推荐文章
一、 Xshell Xftp. 免费软件 Xshell 和 Xftp 都是 NetSarang 出品的优秀网络管理、安全传输工具. Xshell 是一个免费的安全终端仿真器,可以作为 SSH、TELNET 或 RLOGIN 的终端模拟,能够从 Windows 平台安全连接 Linux 服务器,Xftp 则是安全传输客户端,支持 FTP 和 SFTP 协议,两者都支持标签化的会话窗口.

为什么说 AI 无法取代程序员的工作

- -
很多人至今都想不明白为什么我说 AI 无法取代程序员的工作. 他们天真地以为,如果有了超级先进的 AI,那么你只要告诉它”需要什么“,它就能给你做出来. 然而问题就在于——你怎么告诉它“需要什么”. “编程”的实质就是告诉电脑“需要什么”. 要想让 AI 实现人需要的功能,人必须先告诉它“需要什么”.

【高效程序员系列】2、别做机器人——让工作自动化

- etalkr - 博客园-首页原创精华区
每天打开电脑,首先要做的是打开最常用的软件:要和朋友联系,你打开了QQ;要收邮件,你打开了Outlook;要听音乐,你打开了酷狗……但是你不想做机器人,每天重复的打开这些软件,于是你让它们开机启动. 恭喜,你有不做机器人的基本思想. 这些简单重复的操作扔给电脑吧,你需要把宝贵的精力用来做其他更有价值的事.

程序员的工作不能用“生产效率”这个词来衡量

- - 外刊IT评论
通过反复的交谈, Bill Caputo最终说服了我,让我相信了一些不可思议的事情. 这些事情改变了我整个看问题的方式,也让我重新思考如何更好的工作. 几乎正如10年前 Martin Fowler 发现的,用生产效率来衡量软件开发工作没有任何意义. 原因就在于,它们不属于同一范畴. 换句话说,生产效率不具有作为衡量软件开发工作的适用性.

程序员如何成功的假装在很努力的工作

- - 外刊IT评论
i 这篇文章要讲的是程序员如何假装在很努力的工作. 有两种完全不同的动机会促使一个程序员做这种假装:. 第一种,你是个懒货——想不劳而获. 如果你是这种人,我和你同事都会鄙视你. 图1:适当的带一个眼镜,你可以在会议中闭上眼. 第二种,你有太多的事情要做,而你需要抽出时间去思考和学习. 大多数的公司里,经理们或负责人资管理的人都忽略了程序员是脑力工作者、不是做苦力的.

美国一位“天才程序员”将工作外包给中国

- - 创业家杂志社
一家美国重要的基础设施建筑公司发现他们的一位明星程序员居然是把自己的工作外包给了一家中国沈阳的软件公司. 他做了甩手掌柜以后,悠闲地在工作时间冲浪网购,还被公司认为是最高效的程序员之一,是C, C++、Perl、Java、Ruby, PHP和Python方面的专家. 这家公司使用电信运营商Verizon提供的虚拟专用网络,这样员工就可以在家里工作.