




已阅读5页,还剩75页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
软件工程,计算机科学与技术系主讲王里平,1.1软件危机1.2软件工程1.3软件生命周期1.4软件过程1.5软件工程工具小结,2,第1章软件工程概述,1、软件危机、软件工程产生的原因2、软件工程过程和软件生命周期3、软件生命周期模型掌握几个基本概念软件危机软件工程软件过程软件生命周期软件生命周期模型,3,学习重点,软件工程学的产生要从“软件危机”说起1968年,第一届NAT0(北大西洋公约组织的计算机科学家的国际会议)会议,“软件工程”的慨念作为一种有效解决“软件危机”的途径被正式提出。什么是软件危机?软件危机有什么典型表现?为什么会产生软件危机?怎么解决软件危机?,4,软件危机与软件工程学,1.1.1软件危机介绍什么是软件危机?软件危机指在计算机软件的开发和维护过程中,所遇到的一系列严重问题。软件危机主要包括的问题(两方面):如何开发软件如何维护软件,5,1软件危机,开发费用和进度难以估算和控制,大大超过预期的资金和规定日期;软件需求分析不够充分,用户不满意“已经完成”的软件系统。软件质量难于保证;软件维护困难;难以改正程序中的错误;难以根据用户的需要在原有程序中增加一些新的功能。,6,软件危机有什么典型表现?(1),通常没有保留适当的文档资料。文档的作用:软件开发管理人员:用于管理和评价软件开发工程的进展状况软件开发人员:用于开发人员对各个阶段的工作都进行周密思考、全盘权衡、从而减少返工。并且可在开发早期发现错误和不一致性,便于及时加以纠正软件维护人员:软件维护的依据开发成本逐年上升,软件开发生产率提高的速度,远远跟不上计算机应用迅速普及深入的趋势。,7,软件危机有什么典型表现?,8,1966年,IBM360机的操作系统。花费5000人一年的工作量,写了近1万行代码。错误百出,每次的新版本就是从前一版本中找1000个程序错误而修正的结果。1963年,美国用于控制火星探测器的计算机软件中的一个“,”号被误写为“.”,而致使飞往火星的探测器发生爆炸,造成高达数亿美元的损失。美国丹佛新国际机场自动化行李系统软件。投资1.93亿美元,计划1993年万圣节启用。但开发人员一直为系统错误困扰,屡次推后启用时间,直到1994年6月,机场计划者承认无法预测何时能启用。1996年,欧洲阿里亚纳5型运载火箭坠毁,造成5亿美元损失。原因是控制软件中的一个错误。,9,几个软件危机的著名案例,主要两个原因:1、与软件本身的特点有关2、与软件开发与维护的方法不正确有关。,10,1.1.2产生软件危机的原因,软件与硬件、一般程序存在很多不同之处。1、软件与硬件不同抽象性。软件生产没有明显的制造过程,难以衡量开发进展,也难以控制软件质量。问题的隐蔽性。没有硬件的磨损、老化问题,但存在开发早期在分析、设计阶段的错误,修改难度较大。,11,一、软件本身的特点(1),12,失效率蜘线,13,改正一个问题需付出的代价,软件远比一般程序规模庞大,复杂性高软件所反映的实际问题的复杂性程序逻辑结构的复杂性。例1:Windows95,1000万行代码;Windows2000,5000万行代码例2:Exchange2000和windows2000开发人员,14,2、软件与一般程序不同(1),15,软件的规模,软件产品的特殊性和人类智力的局限性,导致人们无力处理“复杂问题”。,大型软件开发既有技术问题,还有社会问题。社会因素:组织机构、体制、管理方式、观念、人的心理素等。开发团队成员分工合作技术与管理的矛盾软件开发人员对软件应用的领域知识的了解,16,2、软件与一般程序不同(2),对用户需求的获取不正确用户的原因分析人员的原因对分析人员的要求:沟通能力、归纳总结能力、经验越是早期产生的错误,付出的代价越大。图:不同时期引入同一变动的代价,17,二、软件开发维护方法中存在的问题(1),软件开发就是编写程序。一个完整的软件产品由一整套完整的配置组成,程序只是其中的一个组成部分。软件开发过程包括多个阶段,每个阶段的产品都是最终的完整的软件产品的一部分。软件开发只要依靠个别编程高手就能完成。轻视软件维护软件维护约占软件费用55一75%,包括修改软件运行的错误;对软件进行改进和功能扩充。,18,二、软件开发维护方法中存在的问题(2),19,软件维护在软件费用的比例,软件开发尚未完全摆脱手工艺的开发方式。软件成本相当昂贵,主要依靠大量复杂的、高强度的脑力劳动软件的开发和运行常常受到计算机系统的限制,对计算机系统有着不同程度的依赖性。软件的“可移植性”就是指的软件对硬件的依赖程度。好的可移植性依赖少。,20,三、其他产生软件危机的原因,1、彻底消除“软件就是程序”的错误观念。2、充分认识到软件开发是一种组织良好、管理严密、各类人员协同配合、共同完成的工程项目,不是个人独立的劳动。3、推广和使用在实践中总结出来的软件开发的成功技术和方法。4、开发和使用更好的软件工具,21,1.1.3消除软件危机的途径,总结:“软件工程”的方法理论是摆脱软件危机的一个主要出路。计算机和软件科学家为解决软件危机问题,尝试将在其它领域中行之有效的工程学知识运用到软件开发工作中来,经过不断实践和总结.最后得出一个结论;按工程化的原则和方法组织软件开发工作是有效的,是摆脱软件危机的一个主要出路。,22,1)只要是编程高手,即使是不懂软件工程,也能编出很好的软件。软件是服务于大众,却是由个性化的开发人员完成的。如果个性化太强,程序就无法阅读,其他人员也就无法维护。例:国内80年代涌现出来的众多汉字操作系统均是由编程高手完成的。,23,思考题(1),2)只要拥有一套讲述如何开发软件的书籍,并了解了书中的标准与示例,就可以解决软件开发中遇到的任何问题。软件是用来解决现实问题的,现实问题的特殊性对规范提出了挑战(要进行适应)。软件技术是发展的,没有祖传秘方。就像拥有食谱并不能成为名厨一样,软件开发需要实践。,24,思考题(2),3)只要拥有最好的开发工具、最好的计算机,一定能做出优秀的软件。硬件环境只是必要条件,人才是充分条件,软件是人在一定的约束条件下创造出来的。因人因事而异。,25,思考题(3),4)软件开发时,如果进度慢,落后于计划,可以增加更多的程序员来解决。增加人力可以减少开发时间吗?新手!任务的重新划分!沟通更加复杂!必须依靠科学地计划来解决这样的问题。,26,思考题(4),5)争议:如果软件运行较慢,是换一台更快的计算机,还是设计一种更快的算法?软件的性能问题;应用级别算法的合理性;系统级别操作系统、数据库系统、系统软件等;硬件级别机器性能,27,思考题(5),1.2.1软件工程介绍一、“软件工程”的典型定义1)1968年,第一届NATO会议为了经济地获得可靠的且能在实际机器上有效地运行的软件,而建立和使用完善的工程原理。2)IEEE/CS(电气电子工程师协会计算机科学分会)1993年,将系统化的、规范的、可度量的方法应用于软件的开发、运行和维护的过程,即将工程化应用于软件中。对中提到的各种方法的研究具体说来,软件工程是以借鉴传统工程的原则、方法,以提高质量,降低成本为目的指导计算机软件开发和维护的工程学科。,28,1.2软件工程,Boehm:运用现代科学技术知识来设计并构造计算机程序及为开发、运行和维护这些程序所必需的相关文件资料。FritzBauer:建立并使用完善的工程化原则,以较经济的手段获得能在实际机器上有效运行的可靠软件的一系列方法所有定义都强调在软件开发过程中,应用工程化原则的重要性,29,3)其他学者的定义,问题一:软件工程适用范围?问题二:软件工程如何控制系统开发的复杂性的?问题三:以你的经验,举例说明一个成熟的软件通常采用什么方法来适应现实世界的变化的?,30,几个关于软件工程本质特性和基本原理的问题,问题四:假设某软件公司,能为同一个用户开发两个不同层次的软件:一个层次的软件功能非常强大,在满足用户所有需求的基础上,还能提供大大超过用户需求的其他更多更强的功能;另一个层次的软件仅仅能满足用户需求,但没有提供其他额外的功能。请问如果你是项目负责人,你会选择为客户开发那个层次的软件?问题五:协同工作有什么重要性?,31,几个关于软件工程本质特性和基本原理的问题,问题五:怎样理解“在软件工程领域中是由具有一种文化背景的人替具有另一种文化背景的人创造产品”这句话?问题六:某软件开发,由于时间和资金都非常紧迫,在需求分析人员非常认真、仔细地做完需求分析之后,说:我们可以保证我们的需求分析正确性,不用花时间检查了,设计人员可以直接拿着这份分析报告,马上开始设计。如果你是项目负责人,你会如何决定?为什么?问题七:在需求分析完成并获得了用户的肯定,也通过了评审,进入软件设计阶段之后,用户的想法有了改变,提出了一个新的要求,此时如果你是项目负责人,应该怎样做?,32,几个关于软件工程本质特性和基本原理的问题,1)软件工程关注于大型程序的构造。2)软件工程的中心课题是控制复杂性主要考虑:如何分解和集成为什么要分解:G.Miller,“7士2”原则3)软件经常变化4)开发软件的效率非常重要5)和谐地合作是开发软件的关键6)软件必须有效地支持它的用户7)在软件工程领域中是由具有一种文化背景的人替具有另一种文化背景的人创造产品扩展定义:软件=知识程序+数据+文档,33,二、软件工程本质特性(2),B.W.Boehm,1983年提出:1)用分阶段的生命周期计划严格管理2)坚持进行阶段评审3)实行严格的产品控制基线基线(baseline)控制4)采用现代程序设计技术5)结果应能清楚地审查6)开发小组的人员应该少而精7)承认不断改进软件工程实践的必要性,34,1.2.2软件工程的基本原理,软件工程包括“管理”和“技术”两方面内容:管理对人、财、物的合理使用和配置;技术指软件开发中采用的方法、工具和过程。什么是软件工程方法学?通常把在软件生命周期全过程中使用的一整套技术方法的集合称为方法学(methodology),也称为范型(paradigm)。,35,1.2.3软件工程方法学,要素一:软件工程过程规定了完成各项任务的工作步骤。要素二:软件工程方法完成软件开发的各项任务的技术方法,为软件开发提供了“如何做”的技术。如项目计划与估算、软件系统需求分析、数据结构、系统总体结构的设计、算法过程的设计、编码、测试以及维护等。,要素三:软件工程工具计算机辅助软件工程CASE(computerAidedsottwareEngineering),为软件工程方法提供自动或半自动的软件支撑环境。,36,一、软件工程方法学三要素:工具、方法和过程,使用定义好的技术集及符号表示组织软件生产的过程目标是在规定的时间和成本内,开发出符合用户需求的高质量的软件常见的软件开发方法结构化方法面向数据结构方法面向对象方法形式化方法问题分析法可视化开发方法,37,二、软件工程方法学思想,采用结构化技术(结构化分析、结构化设计和结构化实现)来完成软件开发的各项任务;把软件生命周期划分为若干个阶段,按顺序完成每个阶段的任务;每个阶段开始和结束都有严格的标准,对任何两个相邻的阶段而言,前一个阶段的结束标准就是后一阶段的开始标准;每一个阶段结束之前都必须进行正式严格的技术审查和管理复审,38,1.传统方法学(生命周期方法学或结构化范型),分解任务,分工合作,降低整个软件开发工程的困难;采用科学的管理技术和良好的技术方法对每个阶段成果都进行严格的审查。保证了软件的质量。传统方法学的缺点:把数据和操作人为地分离成两个独立的部分,增加了软件开发与维护的难度。,39,传统方法学的优点:,模拟人类习惯的思维方式,使开发软件的方法与过程尽可能接近人类认识世界解决问题的方法与过程,从而使描述问题的问题空间(也称为问题域)与实现解法的解空间(也称为求解域)在结构上尽可能一致。,40,2、面向对象方法学(OO,Object-oriented),把对象(object)作为融合了数据及在数据上的操作行为的统一的软件构件。把所有对象都划分成类(class)。按照父类(或称为基类)与子类(或称为派生类)的关系,把若干个相关类组成一个层次结构的系统(也称为类等级)。对象彼此间仅能通过发送消息互相联系。,41,面向对象方法学4要点,结构化方法:强调自顶向下顺序地完成软件开发的各阶段任务。面向对象方法:是主动地多次反复迭代的演化过程,42,二者区别,一、什么是软件生命周期(lifecycle)指软件孕育、诞生、成长、成熟、衰亡的生存过程GB一8567中将软件生命周期分为7个阶段:可行性研究和项目开发计划;需求分析;总体(概要)设计;详细设计;编码;测试;维护其他分法,5个阶段:需求定义、设计、编码、测试及维护;需求定义阶段包括可行性研究和项目开发计划、需求分析;设计阶段包括慨要设计和详细设计。,43,3软件生命周期,44,对软件生命周期的划分,任务:确定软件开发工程必须完成的总目标;确定工程的可行性;导出实现工程目标应该采用的策略及系统必须完成的功能;估计完成该项工程需要的资源和成本,并且制定工程进度表。通常分为问题定义、可行性研究和需求分析三个阶段。,45,1、软件定义时期,问题定义阶段回答:回答:要解决的问题是什么?可行性研究阶段回答:对于上一个阶段所确定的问题有行得通的解决办法吗?需求分析(RequirementAnalysis)回答:为了解决这个问题,目标系统必须做什么?用正式文档准确地记录对目标系统的需求,这份文档通常称为规格说明书(specification)。,46,软件定义时期的三个阶段,具体设计和实现前一个时期定义的软件,通常分为四个阶段:总体设计(概要设计)回答:“概括地说,应该怎样实现目标系统?”根据需求分析,设计软件的体系结构;定义结构中的组成模块。详细设计(模块设计)回答:“应该怎样具体地实现这个系统呢?”对每个模块要完成的工作进行具体的描述,为源程序编写打下基础。编写设计说明书,提交评审。二者统称系统设计,47,2、软件开发时期,程序编写(Coding,Programming):把软件设计转换成计算机可以接受的程序代码。软件测试(Testing):按规定的各项需求,逐项进行有效性测试,决定已开发的软件是否合格,能否交付用户使用,包括单元测试和组装测试。二者统称系统实现,48,软件开发时期四个阶段,使软件持久的满足用户的需要。包括:改正性维护:运行中发现了软件中的错误需要修正。适应性维护:为了适应变化了的软件工作环境,需做适当变更。完善性维护:当用户有新的要求时,应该及时改进软件以满足用户的要求。预防性维护:即修改软件为将来的维护活动预先做准备。,49,3、运行维护(软件维护)时期(Running/Maintenance),问题一:开发一个软件大概需要多少资金、时间,将获得什么效益一般是在哪个阶段确定?相对而言,在哪个阶段与用户交流最多?问题二:系统分析员主要工作在哪个时期?程序员主要工作在哪个时期?问题三:软件定义时期的三个阶段,各自回答什么关键问题?问题四:软件开发时期有几个阶段?各自回答什么关键问题?,50,几个关干软件生命周期阶段的问题,问题五:软件体系结构最早是在哪个阶段决定的?问题六:详细设计与程序编写阶段有什么样的密切联系?问题七:“软件测试是为了验证系统的正确性”这句话对吗?问题八:软件维护有那几种?各有什么功能?,51,1、什么是软件过程为了获得高质量软件所需要完成的一系列任务的框架,它规定了完成各项任务的工作步骤。ISO9000的定义:使用资源将输入转化为输出的活动所构成的系统。“系统”是相互关联或相互作用的一组要素。过程是软件工程三要素之一。通常用软件生命周期模型来描述。,52,1.4软件过程(SoftwareProcess),又称:软件开发模型软件过程模型软件工程范型。指软件项目从需求定义直至软件经使用后废弃为止,跨越整个生存周期的系统开发、运作和维护所实施的全部过程、活动和任务的结构框架。常见的有:瀑布模型、演化模型、螺旋模型、喷泉模型、智能模型,53,2、什么是软件生命周期模型,1970年,由W.Royce提出一、瀑布模型的过程1、传统的瀑布模型从上一阶段接受本阶段的工作对象,作为输入;利用输入,完成本阶段活动的内容本阶段的工作成果作为输出传入下一阶段。,54,1.4.1瀑布模型(waterfallmodel),增加了一个评审活动,评审每个阶段完成的活动,若得到确认,则进行下一阶段的活动;否则返回前一阶段,甚至更前阶段返工;,55,瀑布模型实际的瀑布模型,阶段间具有顺序性和依赖性推迟实现的观点质量保证的观点,56,二、瀑布模型特点,优点:可强迫开发人员采用规范的方法;严格地规定了每个阶段必须提交的文档;要求每个阶段的所有产品都必须经过质量保证小组的仔细验证;缺点:无法解决软件需求不明确或不准确的问题;可能导致最终开发的产品不能真正满足用户需要。瀑布模型比较适合开发需求明确的软件。,57,三、瀑布模型优缺点,1、什么是“原型”?原型是快速实现和运行的早期版本,反映最终系统部分重要特性。常见的原型实例:人机界面;系统主要功能。优点:1、通常能反映用户真实需求;2、软件产品的开发基本上是线性顺序进行的。,58,1.4.2快速原型模型,如右图。获得用户的基本需求说明,据此快速建立一个小型软件系统用户试用,对其评价;开发人员按照用户的意见快速地修改原型系统,获得新的原型版本,再请用户试用,如此反复,直到满足用户的要求;用户确认原型系统之后,开发人员据此书写规格说明文档,进行下一步开发。,59,2、快速原型的过程,把软件产品作为一系列的增量构件来设计、编码、集成和测试。每个构件由多个相互作用的模块构成,并且能够完成特定的功能。使用增量模型时,第一个阶段的增量构件往往实现软件的基本需求,提供最核心的功能;后面的增量构架逐渐添加系统的功能。,60,1.4.3增量(渐增)模型,61,图:增量(渐增)模型,增量构件规模适中;分解的约束条件是当把新构件集成到现有软件中时,所形成的产品必须是可测试的;软件体系必须是开放的,即在对现有系统添加新增量构件时,不能破坏系统原有功能。,62,增量模型注意事项,优点:能在较短的时间内,提供可完成部分工作的初步产品给用户;用户有较为充裕的时间学习和适应新产品。缺点:对开发人员技术能力要求较高,要求能从系统整体出发正确划分增量构件,并进行分别开发,最后能很好地集成这些构件。,63,增量模型优缺点,有可能提高开发速度,但需要密切地监控整个开发过程,否则将冒构件无法集成到一起的风险,。,64,一种风险更大的增量模型,分析,分析,分析,分析,设计,设计,设计,设计,编码,编码,编码,编码,测试,测试,测试,测试,构件1,构件2,构件3,构件4,大型软件开发面临的重要问题:软件风险如:产品交付给用户之后,用户不满意;开发进度落后,开发成本超出预算;产品完成前关键的开发人员跳槽;在产品投人市场前,竞争对手发布了一个功能相近,价格更低的软件构建原型能使某些类型的风险降到最低.,65,1.4.4螺旋模型(spiralmodel),螺旋模型改进了原型模型,在每个阶段都加入风险分析。,66,一、简单的螺旋模型,图1.7简化的螺旋模型,图1.7简化的螺旋模型,图1.7简化的螺旋模型,67,二、完整的螺旋模型,优点:强调可选方案和约束条件,有利于已有软件的重用,也有助于把软件质量作为软件开发的一个重要目标;减少了过多测试(浪费资金)或测试不足(产品故障多)所带来的风险;维护是一个周期,与开发并没有本质区别缺点:需要开发人员具有相当丰富的风险评估经验和专门知识;进行风险分析的费用可能较大。适合大型软件开发,68,螺旋模型的优缺点,各种模型的比较,69,1.5软件工程工具,70,软件工程工具通常有三种分类标准按照功能划分:可视化建模工具、程序开发工具、自动化测试工具、文档编辑工具、配置管理工具、项目管理工具按照支持的过程划分:设计工具、编程工具、维护工具按照支持的范围划分:窄支持(工具)、较宽支持(工作台)和一般支持工具(环境),1.5软件工程工具,71,经常会使用到的软件工程工具分析设计工具:MicrosoftVisio,RationalRose,Together,PowerDesigner,CASEStudio程序开发工具:MicrosoftVisualStudio,Eclipse,NetBeans,Delphi,DevC+测试工具:LoadRunner,WinRnnner,Segue配置管理工具:MicrosoftVisualSourcesafe,ClearCase项目管理工具:MicrosoftProject,CA-SuperProject,TimeLine,72,第一章小结,1、软件危机指在计算机软件的开发和维护过程中,所遇到的一系列严重问题。软件危机主要包括的问题(两方面):如何开发软件如何维护软件最后得出一个结论;按工程化的原则和方法组织软件开发工作是有效的,是摆脱软件危机的一个主要出路。,73,第一章小结,2、软件工程一、“软件工程”的
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年公安辅警招聘知识考试题库及答案
- 中国银行鞍山市铁西区2025秋招笔试英语完形填空题专练30题及答案
- 中国银行南宁市良庆区2025秋招笔试英语选词填空题专练50题及答案
- 中国银行通辽市科尔沁左翼后旗2025秋招半英文面试题库及高分答案
- 2025年大学经济犯罪侦查专业题库- 经济犯罪侦查专业就业方向分析
- 中国银行喀什地区疏勒县2025秋招笔试英语阅读选词题专练30题及答案
- 邮储银行北海市铁山港区2025秋招半英文面试题库及高分答案
- 邮储银行山南市琼结县2025秋招笔试英语阅读理解题专练30题及答案
- 邮储银行安庆市桐城市2025秋招笔试会计学专练及答案
- 中国银行清远市连州市2025秋招笔试会计学专练及答案
- 2025房屋宅基地买卖合同
- 高一物理力学知识点总结与测试题
- 广东省深圳市罗湖区2025-2026学年高三第一学期开学质量检测语文(含答案)
- 2025年南网春招笔试试题及答案
- 2025餐饮业简易劳动合同范本下载
- 基于PLC的果园灌溉施肥系统设计
- 南通蓝浦环评报告书
- 商户维护与管理办法
- 2025年武汉市中考英语试卷真题(含答案)
- 无人机清洗玻璃幕墙技术规范
- 浙江省舟山市2024-2025学年高二下学期6月期末物理+答案
评论
0/150
提交评论