zoukankan      html  css  js  c++  java
  • 人月神话阅读笔记之二

    《人月神话》第二章主要讲的是软件工程的滞后灾难的出现及其原因,它比其他因素造成的影响加起来还要大。

    首先,在软件工程项目中缺乏合理的进度安排是造成项目滞后的主要原因。前期对项目缺少研究,对自己的估算缺乏信心,实现过程中对进度缺少监督和跟踪,下意识增加人力造成火上浇油等都是缺乏合理进度安排造成的影响。在我们目前阶段的学习以及团队开发过程中,更可能出现进度预测不准确的原因是,我们无法对自己的能力有个合理的估算,也无法对于自己每天能完成的工作量和专心程度做正确的估算,而且没有经验也是一大主要原因。

    之前曾经听别的学长说软工是吃青春饭的,开始不理解,现在有些认识了。年轻人很多都是乐观主义者,他们很习惯的会说出“这次肯定运行成功”之类的话。所以这些乐观主义者也是造成项目滞后的原因,他们没有看到目前的软件所存在的问题。很多交织和累积的问题。

    人月作为衡量一项工作的规模是一个危险的和带有欺骗性的神话,这也就是“人月神话”这个名称的由来。人员和时间互换仅仅适用于任务可以分配给参与人员,并且他们之间不需要交流。但是软件工程是一项浩大的工程,需要大量的沟通交流,如果增加人手,则需要更多的交流,这样下去可能造成相反的效果,所以说大的软件项目中,不可能存在人月神话的模式,之所以称之为神话,我想原因也在此吧。

    之前老师讲到过单元测试。单元测试是用来更正缺陷。由于乐观主义,导致出现了BUG,然后我们就需要进行单元测试,因而书中说,系统测试进度的安排常常是编程中最不合理的部分。

    编程人员像厨师,进度受顾客施压影响。这就像我们平常做作业一样,那个老师厉害,先把哪门作业完成,但是质量不敢保证。项目负责人员根据自己的经验,为了迎合顾客的需求,从而做出了一个并不合理的进度估计。从根本上说,是对自己和项目以及顾客的极其不负责任,很容易失去用户。

    向进度处于落后的项目添加人手,是一个不理智的决定,甚至可能造成进度更加落后。这就是重复产生的灾难。添加人手后需要培训,对项目任务重新分配,这也需要消耗时间,而且新添加的人手需要的交流更多,而且在某项情况下,原先已经做好的某些项目可能会丢失,这还是在不考虑每个人工作习惯的情况下。这也就产生了所谓的Brooks法则--向进度落后的项目增加人手,只会使使进度更加落后。

    因此,为了避免对项目造成滞后的影响,就要对项目进度有合理安排,这是最主要的,其次要避免乐观主义,进度落后的时候不要添加人手。

  • 相关阅读:
    Hive学习小记-(4)带复杂集合类型及指定多分隔符hive建表
    nowcoder-shell篇(grep、awk、sed为主)
    剑指offer02-替换空格
    剑指offer67-剪绳子**
    爬虫5-Scrapy爬虫架构
    爬虫4-网站结构分析
    爬虫3-python爬取非结构化数据下载到本地
    项目创建
    项目框架搭建
    项目表结构
  • 原文地址:https://www.cnblogs.com/my1204/p/5585235.html
Copyright © 2011-2022 走看看