《梦断代码》读后感——史经浩

image

这本书放在我手上很久了,之前只是略微的翻一翻,书的确很有趣,但是事情比较多,没怎么仔细看。后来迫于邹欣老师的压力,才逼着自己抽出时间来看,加上我是我们team的PM,感受还是蛮深刻的。

  • 像造桥那样造软件
    书中说道,“关于软件缺陷的话题,只要谈上几分钟,必会有人拍案叹道,‘为什么就是不能像造桥那样造软件?’”的确,掩卷长思,为神马不能像造桥那样造软件哪!细想起来,两者之间的根本不同在于,一个是体力劳动,以机械为主;一个是脑力劳动,以人为主。人,从来就不是一个确定的东西,有喜怒哀乐,有自己的偏爱和偏见,充满了各种不确定性,以它为主的项目,自然不可能做到分毫不差。软件工程的主要目的,就是尽量把这种不确定性从项目中剥离出来,使做软件真正成为一个工程,而不是个人英雄主义的胡拼乱凑。
    image
  • 人月神话
    之前只是听过《人月神话》的鼎鼎大名,但是没怎么认真读过。《梦断代码》在讨论“软件时间”这一概念时,其中,布鲁克斯提出了一个十分著名的法则,“往以延误的项目中补充人力,只会使其继续厌恶”,这听起来像是一个悖论,但是其后无数年间的实践,这一原则都成了程序猿和开发经理的梦魇,他们“宁愿装作法则并不适用于自己,也不肯与之妥协“。布鲁克斯指出了其中要害,”只有在任务能分派给许多相互之间无须沟通的工作者时,人和月才是可互换品。“制作软件的大量工作受困与”序列约束“”,它限制的任务分解的程度:完成某项任务是处理其他任务的先决条件,这与人力投入多少无关。“十月怀胎,无论多少妇女参加都一样。”想想也是,一个完整的软件项目,必然要按照一定的流程来进行,诸如用户需求分析,详细设计等等,人力再多,有时也无法加快各个阶段的进度,反而可能会因为交流不畅而拖累整个项目。
    image
  • 团队角色之鸡与猪
    这个观点来自邹欣老师的软件工程课,说的是一个团队中,或许有两种根本上不同的角色,一种称之为鸡,只提供鸡蛋就好,项目搞砸了也没事,反正鸡蛋还可以再下,拍拍屁股走人即可;另一种称之为猪,是要割肉的,项目不能搞砸,不然肉又不会再长,反而可能割肉太多而死掉。敏捷宣言的原则中也提到,要把重要工作交给那些有足够motivations的成员,不然的话很难有大的推进。在chandler项目中,我好想没有看到猪,鸡倒是有很多,很多人加入到这个项目中都是出于热情,当项目受到挫折时,很难保证这些人不会退却。
    image
posted @ 2010-12-18 15:52  MSRA_SE_TEAM  阅读(522)  评论(1编辑  收藏  举报