高级软件开发过程——Rational统一过程、敏捷过程与微软过程-第一章.docVIP

高级软件开发过程——Rational统一过程、敏捷过程与微软过程-第一章.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PAGE 10 高级 PAGE 9 第1章 绪论 第 1 第 1 章 绪 论 1946年,世界上第一台电子计算机诞生在美国宾夕法尼亚大学的摩尔学院,由此拉开了计算机软件的发展史。从宏观角度而言,计算机软件的发展主要经历了以下三个阶段[1]。 (1)第一阶段——程序设计阶段 20世纪60年代以前还没有软件开发的说法,那时只有程序设计的概念,最多在写出程序后配有程序结构说明和使用说明。经典的程序设计方法为“程序设计=数据结构+算法”。 (2)第二阶段——软件工程阶段 20世纪70年代以来,人们认识到软件的工作不能仅限于编写程序,软件开发工作在程序编写之前和之后还有很多重要的工作不能忽略,例如需求分析、测试、维护等等。在总结“软件危机”教训后,人们认识到并建立了软件工程的思想。软件工程摒弃了认为只有充满编程技巧的程序才能高水平地发挥个人才能的观念,强调程序的可读性、可理解性、可测试性和易修改性等工程化的原则。 (3)第三阶段——软件过程阶段 从20世纪90年代开始,人们更加强调软件开发的效率、软件的质量以及与软件开发相关的管理工作,建立了“软件过程”的概念。软件过程不仅包括软件开发过程,还包括了支持性、管理性过程。 以上发展历程表明,通过实践、总结、再实践、再总结……人们对软件这门实践学科的理解正朝着更全面、更系统、更深刻的方向发展。 1.1 现代软件产业的困境 1.1.1 困境中的现代软件产业 当今,全球市场变幻莫测,用户需求日趋复杂,IT技术日新月异。软件企业组织在不断变化的市场和技术环境中能否取得成功,关键在于企业组织是否能在市场许可的期限和有限资源条件下不断推出满足用户需求的产品。 然而,现代软件产业的总体情况并不理想。下面先来看一个真实的案例[14]。 Square Cal 3.0版本计划在2.0版本上市后的10个月内发布。项目经理Mickey和上司Kim讨论后决定:他们将为项目组成员提供私人办公室、最新型的计算机以及免费的碳酸饮料,并且要求开发者在前8个月按照预先设计好的接口各自开发,8个月之后进行可视化锁定,在最后2个月内完成系统集成。这是一个完美的计划。于是项目组成员各自做着自己的工作。随着可视化锁定日期的来临,他们开始进行代码集成。他们在可视化锁定最终截止日期前一天的下午两点开始工作,但很快发现程序不能编译通过,更不用说运行了。代码在编译时有数十个错误,而似乎每处理一个错误就会产生十个以上的新错误。他们一直干到午夜也没有结果,只好决定第二天再说。但测试发现问题的速度远比开发人员解决问题的速度快,解决系统某一部分的错误经常会导致其他部分的新问题。项目超期,项目组成员在巨大的压力下工作,士气逐渐低落。最后整个软件开发过程用了15个月时间,即超过了项目计划时间的50%,公司错过了最佳的产品发布日期。产品发布后,用户对Square Cal 3.0版本反映冷淡,在几个月的时间内其市场份额从第二位下降到第四位。 再看一组统计数据。图1-1[12]是根据最近一次项目调查得到的某公司所有软件项目的完成情况。从图中可以看出,出现问题的项目和中途取消的项目所占比例远高于顺利完成的项目。实际上,图1-1代表了整个现代软件产业的现状,很多软件项目最终不能交付,或者最终交付的软件项目进度发生延期、成本超出预算,而且运行经常不可靠。因此,诸如“软件开发的滑铁卢”(Software Runaways)[2]、“死亡之旅”(Death March)[3]之类关于软件失败项目的报道不时见诸于媒体报端也就不足为奇。 图1-1 项目完成情况图 1.1.2 陷入困境的根源 众所周知,现代计算机和因特网的性能在逐年增强,用户对运行于计算机和因特网上的软件的功能和性能的渴望也随之不断增加,用户希望得到越来越复杂的软件系统以满足其需求;与此同时,市场的激烈竞争迫使现代软件企业必须更快地生产出用户需要的复杂软件。然而,现今大多数软件企业及其开发人员仍然沿用二三十年前的软件组织方式和开发方法来开发软件系统,这就是现代软件产业陷入困境的根源所在。 具体总结、归纳起来[2], [5], [12],大多数软件项目失败的根本原因主要有以下几个方面。 不完整、不现实的项目需求描述:需求分析过程中缺乏用户参与或与用户的交流过于模糊,常导致给出的需求描述不完整、不准确,需求项过多、需求项实现难度过高等。 对需求的变更束手无策:需求的变更往往是现实世界变化的反映,合理的需求变更在项目的某些阶段是允许的,这要求开发过程对需求变更具有应对能力。 脆弱的架构:表现为程序模块互不兼容,软件不易扩展、裁剪和移植。 采用不成熟的技术:表现为新技术不具有要求的功能、新技术存在局限性或者新技术是问题的错误解决方案。 测试的不充分性:未检测出需求、设计和实现三者之间的不一致。

文档评论(0)

150****8484 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档