微软项目求生法则 求生心态之求生概念3(转)

本文提供了一套更精巧的软件开发程序。

建立系统化软件开发程序的障碍之一,就是项目团队害怕自己会在面对太多开发程序项目时出错,害怕他们执行这些程序后,会变得太官僚化,对项目执行造成太大负担。这通常不构成显著的危险,因为:

◆使用本文做法的项目会有个相当精细的开发程序,不会带来太多负担。
◆软件项目常常比第一眼看起来的要大得多。多数项目的问题出在本身,而不是出在开发程序中。
◆比较好的做法是开始先设定较多的开发程序以供执行、再视情况调整,比开头毫无章法其后再追加额外程序项目要容易。
◆多设定些程序项目所花的成本与时间代价要远低于不重视这档子事。接下来,就告诉你为何如此。

上下游

好的软件开发程序可及早处理项目中的问题。

你有时会听到经验老到的软件开发人员提起软件项目中的“上游”跟“下游”部分。“上游”这字眼只是用来表示项目的开始部分,“下游”则是指项目的末尾部分。

“上下游”的分法对于思考项目上的问题是很有用的。开发人员在项目开始所做的,在末尾未必有收获。如果一开始工作处理得当,末尾的收获就会健全并有助于项目成功。如果开始工作做得不好,后来的结果就可能严重影响成果,不客气地说,甚至可能让项目无法完成。

研究人员发现诸如规格或架构上的错误,事后才修正会比一开始就修正错误要花费多出50~200倍的代价。图3-5说明了这种效应。


mspm4.gif

要能让规格中的一句话很容易变成几个设计方式,而这些设计方式之后能再变成几百行的源代码、几打的测试情形、许多页的使用文件、线上求助画面及许多技术支持部门的操作说明等等东西。

当项目团队有机会阶段性修正错误,立刻修正错误会比过一阵子再去修正受影响之处要有意义。这种在错误发生的阶段内找出错误并马上休正的构想称作“阶段围堵”策略。

============================================
成功的项目借由仔细审查、要求规格与架构来制
造机会修正上游问题。
============================================

在上游动作时还没写出任何程序,找寻及修正错误,虽然可能让项目“该做的工作”表面上看来被拖延了,实际上却刚好相反。这些工作是在替项目的成功铺路。

过多程序项目的错误会越发的增加项目的负担,不过缺乏程序规划的问题会让错误变成必须花费50~200倍的效率成本才能修正的大麻烦。因此宁可多设定开发程序事项,也比不做开发程序设定来得好。

不确定性的角锥

上游错误要多花费50~200倍的代价才能在下游修正的一个原因是,上游决定的范围比下游的要广。

在项目初期,项目团队面对的是大问题,例如要不要同时支持Windows NT或Macintosh或是只支持Windows NT就好了,还有报表格式是使用者自订还是固定格式。在项目进行中,项目团队面对的是中型问题:有多少子系统;如何按一般情形处理错误状况;或是如何把一个打印例程从过去的项目移植到现在的项目中。

到了项目末期,项目团队面对的是小问题,像是要采用哪一种技术算法,或者要不要让使用者能够取消还没完成的动作等等。如图3-6所示,软件开发是个持续渐进的程序,将问题由大到小分开处理,从决定大势走向到解决个别的小问题。推动软件项目所花费的时间,就是彻底思考并解决问题所需要的时间。

本图中的角锥状图形为项目中决策方向未定的事务量。软件项目中对问题的决策尺度由大到小。除非团队成员完成了前一个阶段的大部分工作,不然无法知道一个特定阶段中到底有多少需要决定执行方向的问题。

项目团队最擅于处理大型的决策问题,不过有时无法预见(而且不可预知的)的问题会在后头因为大型决策不当而出现,若要中途取消一个行动则表示项目团队得重新设计一个常式、一个模块甚至一整个子系统。

mspm5.gif

在某一尺度的决策敲定后,应可以事先精确预估下一尺度将面对的决策种类。不过项目团队或许可以先做好前头的决定,但对项目后头的决策问题只可能作出一般性的猜测。如果你想知道软件开发的工作为何,了解项目团队所有该思考的问题,并明白一个团队得在充分了解下一个阶段工作的内容之前便决定好现阶段中所有的执行方向,就成了重要的事情。

不确定性的角锥对项目预估的意义

不确定性的角锥对软件项目的预估有着强烈的意义。它不光表示在前期阶段精确评估项目的困难性,还说明那在理论上不可能办到。在需求规格阶段末尾,项目的范围还得由一大堆在购架阶段、细节设计阶段和构建阶段要作出的决策所决定。宣称能够预估未定决策对项目影响有多大的人如果不是先知,就是对于软件开发的本质不太了解的人。

另一方面,寻求控制决策方向以符合项目预计时间或预算目标的人是明智的。只要你愿意痛下决心砍掉一些规划功能,在项目初期就确立精确的时间表和预算目标,并在之后一直按部就班。成功的关键在于以这样的方式达成目标要求,做法包括在项目初期设定明确而不冲突的目标,保持产品概念非常有弹性,并主动追踪控制项目中的开发工作。

==============================================================
在项目开头,你能制定实在的成本和时间目标,或是制定充实的功能
组合,但是你不能强求两边的目标都要达成。
==============================================================[@more@]

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/7839396/viewspace-942020/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/7839396/viewspace-942020/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值