如何理解软件与软件工程.docx
《如何理解软件与软件工程.docx》由会员分享,可在线阅读,更多相关《如何理解软件与软件工程.docx(31页珍藏版)》请在三一文库上搜索。
1、第一章软件与软件工程1. 1软件(Software)1.1.1 软件与软件的组成计算机软件一一与计算机系统操作有关的程序、规程、规则及任何与之有关的文档和数据。软件程序及有关数据一机器可执行;文档(与软件开发、运行、维护、使用、培训有关)不可执行。程序(PrOgram)用程序设计语言描述的,适合于计算机处理的语句序列。程序设计语言三种类型:1 .机器语言、汇编语言:依赖于机器,面向机器2 .高级语言:独立于机器,面向过程或面向对象3 .面向问题语言:独立于机器,非过程式语言(4GL)文档(document)一种数据媒体和其上所记录的数据。文档记录软件开发活动和阶段成果,具有永久性,可供人或机器
2、阅读。文档可用于专业人员和用户之间的通信和交流;软件开发过程的管理;运行阶段的维护。1 .软件的特点软件是逻辑产品,硬件是物理产品。特点:(软件开发更依赖于开发人员的业务素质、智力、人员的组织、合作和管理。软件开发、设计几乎都是从头开始,本钱和进度很难估计。(2)软件存在潜伏错误,硬件错误一般能排除。(3)软件开发成功后,只需对原版进行复制。(4)软件在使用过程中维护复杂:D纠错性维护一改正运行期间发现的潜伏错误;2)完善性维护一提高或完善软件的性能;3)适应性维护一修改软件,以适应软硬件环境的变化;4)预防性维护一改良软件未来的可维护性和可靠性。(5)软件不会磨损和老化。2 软件的开展第一阶
3、段一一20世纪60年代中期以前,软件开发处于个体化生产状态。在这一阶段中,软件还没有系统化的开发方法。目标主要集中在如何提高时空效率上。第二阶段一一从20世纪60年代中期到70年代末期。软件开发已进入了作坊式生产方式,即出现了“软件车间。软件开发开始形成产品。到20世纪60年代末,“软件危机变得十分严重。第三阶段一一从20世纪70年代中期到20世纪80年代末期。软件开发进入了产业化生产,即出现了众多大型的“软件公司。在这一阶段,软件开发开始采用了“工程的方法,软件产品急剧增力口,质量也有了很大的提高。第四阶段一一从20世纪80年代末期开始的。这是一个软件产业大开展的时期。也是软件工程大开展的时
4、期,人们开始采用面向对象的技术和可视化的集成开发环境。1. 1.2软件危机软件危机是指在计算机软件开发、使用与维护过程中遇到的一系列严重问题和难题。1 .软件危机的表现1)对软件开发本钱和进度的估计常常很不准确。常常出现实际本钱比估算本钱高出一个数量级、实际进度比方案进度拖延几个月甚至几年的现象,从而降低了开发商的信誉,引起用户不满。2)用户对已完成的软件不满意的现象时有发生。3)软件产品的质量往往是靠不住的。4)软件常常是不可维护的。5)软件通常没有适当的文档资料。文档资料不全或不合格,必将给软件开发和维护工作带来许多难以想象的困难和难以解决的问题。6)软件本钱在计算机系统总本钱中所占比例逐
5、年上升。特别是软件维护本钱迅速增加,已经占据软硬件总本钱的40限75%。7)开发生产率提高的速度远跟不上软件需求。60%40%20%1955年1970年1985年oo%80%图1-1-1软件、硬件成本变化焰势2 .产生软件危机的原因1)用户对软件需求的描述不精确。2)软件开发人员对用户需求的理解有偏差,这将导致软件产品与用户的需求不一致。3)缺乏处理大型软件工程的经验。开发大型软件工程需要组织众多人员共同完成。一般来说,多数管理人员缺乏大型软件的开发经验,而多数软件开发人员又缺乏大型软件工程的管理经验,致使各类人员的信息交流不及时、不准确、容易产生误解。4)开发大型软件易产生疏漏和错误。5)缺
6、乏有力的方法学的指导和有效的开发工具的支持。软件开发过多地依靠程序员的“技巧,从而加剧了软件产品的个性化。6)面对日益增长的软件需求,人们显得力不从心。从某种意义上说,解决供求矛盾将是一个永恒的主题。3 .缓解软件危机的途径到了20世纪60年代末期,软件危机已相当严重。这促使计算机科学家们开始探索缓解软件危机的方法。他们提出了“软件工程的概念,即用现代工程的原理、技术和方法进行软件的开发、管理、维护和更新。于是,开创了计算机科学技术的一个新的研究领域。1.2软件工程的概念1.2.1软件工程的定义1968年,北大西洋公约组织在原西德召开计算机科学会议,由FritZBaUer首次提出了“软件工程的
7、概念。软件工程一一用工程、科学和数学的原则与方法开发、维护计算机软件的有关技术和管理方法。软件工程由方法、工具和过程三局部组成,称软件工程的三要素。1. 2.1软件工程的定义 软件工程中的各种方法是完成软件工程工程的技术手段,它们支持软件工程的各个阶段。 软件工程使用的软件工具能够自动或半自动地支持软件的开发、管理和文档的生成。 软件工程中的过程贯穿于整个工程的各个环节,在这一过程中,管理人员应对软件开发的质量、进度、本钱等进行评估、管理和控制,包括方案跟踪与控制、本钱估算、人员的组织、质量保证、配置管理等1.2.2软件工程的根本原理著名的软件工程专家B.W.BOehm于1983年综合了软件工
8、程专家学者们的意见并总结了开发软件的经验,提出了软件工程的7条根本原理。这7条原理被认为是确保软件产品质量和开发效率的原理的最小集合,又是相互独立、缺一不可、相当完备的最小集合。下面就简单介绍软件工程的这7条原理:1 .用分阶段的生存周期方案严格管理2 .坚持进行阶段评审3 .实行严格的产品控制4 .采用现代程序设计技术5 .结果应能清楚地审查6 .开发小组的人员应少而精7 .成认不断改良软件工程实践的必要性1.2.3 软件工程的目标软件工程的目标是在给定本钱、进度的前提下,开发出具有可修改性、有效性、可靠性、可理解性、可维护性、可重用性、可适应性、可移植性、可追踪性和可互操作性并满足用户需求
9、的软件产品。名词解释1)可修改性(modifiability),允许对软件系统进行修改而不增加其复杂性。它支持软件调试与维护。2)有效性(efficiency),指软件系统的时间和空间效率。这是一个应当努力追求的重要目标。3)可靠性(reliability),是指在给定的时间间隔内,程序成功运行的概率。可靠性是衡量软件质量的一个重要目标。4)可理解性(UnderStandability),指系统具有清晰的结构,能直接反映问题的需求。可理解性有助于控制软件系统的复杂性,并支持软件的维护、移植和重用。5)可维护性(maintainability),是指软件产品交付使用后,在实现改正潜伏的错误、改良
10、性能等属性、适应环境变化等方面工作的难易程度。由于软件的维护费用在整个软件生存周期中占主要的比重,因此,可维护性是软件工程中的一个十分重要的目标。软件的可理解性和可修改性支持软件的可维护性。6)可重用性(reusability),是指软部件可以在多种场合使用的程度。概念或功能相对独立的一个或一组相关模块可构成一个软部件。软部件应具有清晰的结构和注释、正确的编码和较高的时空效率。可将各种软部件按照某种规则放在软部件库中供开发人员选用。广义地讲,可重用性还应包括应用工程、规格说明、设计、概念和方法等等的重用。一般来说,重用的层次越高,带来的效益越可重用性有助于提高软件产品的质量和开发效率、降低软件
11、开发和维护费用。7)可适应性(adaptability),是指软件在不同的系统约束条件下,使用户需求得到满足的难易程度。选择广为流行的软硬件支持环境、采用广为流行的程序设计语言编码、采用标准的术语和格式书写文档可增强软件产品的可适应性。8)可移植性(POrtability),是指软件从一个计算机系统或环境移植到另一个上去的难易程度。采用通用的运行支持环境和尽量通用的程序设计语言的标准局部可提高可移植性。而应将依赖于计算机系统的低级(物理)特征局部相对独立、集中起来。可移植性支持软件的可重用性和可适应性。9)可追踪性(traceability),是指根据软件需求对软件设计、程序进行正向追踪,或根
12、据程序、软件设计对软件需求进行逆向追踪的能力。软件开发各阶段的文档和程序的完整性、一致性、可理解性支持软件的可追踪性。10)可互操作性(interoperability),是指多个软件元素相互通信并协同完成任务的能力。1.2.4 软件工程的原则1 .抽象(abstraction),抽取各个事物中共同的最根本的特征和行为,暂时忽略它们之间的差异。一般采用分层次抽象的方法来控制软件开发过程的复杂性。抽象使软件的可理解性增强并有利于开发过程的管理。2 .信息隐藏(informationhiding),将模块内部的信息(数据和过程)封装起来。其他模块只能通过简单的模块接口来调用该模块,而不能直接访问该
13、模块内部的数据或过程,即将模块设计成“黑箱。信息隐藏的原则可使开发人员把注意力集中于更高层次的抽象上。3 .模块化:4 .局部化(localization),即在一个物理模块内集中逻辑上相互关联的计算资源。局部化支持信息隐藏,从而保证模块之间具有松散的耦合、模块内部有较强的内聚。这有助于控制每一个解的复杂性。5 .一致性(COnSiStenCy),整个软件系统(包括程序、数据和文档)的各个模块应使用一致的概念、符号和术语;程序内部接口应保持一致;软件与环境的接口应保持一致;系统规格说明应与系统行为保持一致;用于形式化规格说明的公理系统应保持一致。6 .完全性(completeness),软件系
14、统不丧失任何重要成分,完全实现所需的系统功能的程度。为了保证系统的完全性,在软件的开发和维护过程中需要严格的技术评审。7 .可验证性(Verifiability),开发大型软件系统需要对系统逐层分解。系统分解应遵循易于检查、测试、评审的原则,以使系统可验证。抽象、信息隐藏、模块化和局部化的原则支持可理解性、可修改性、可靠性等目标,并可提高软件产品的质量和开发效率;一致性、完全性和可验证性等原则可以帮助软件开发人员去实现一个正确的系统。1.3软件生存周期软件从定义开始,经过开发、使用和维护,直到最终退役的全过程称为软件生存周期。可将软件生存周期划分为3个过程共9个阶段。3个过程是:软件定义过程、
15、软件开发过程、软件使用与维护过程。9个阶段有:可行性研究、需求分析、概要设计、详细设计、实现、组装测试、验收测试、使用与维护、退役。它们之间的关系如图3-1所示。定工程I可行性研彳J需求分析口既要设计详细设计开发过程实现组装测试作收测试用与维护使用与维护过程_L1退役(图1-3T)1. 3.1软件定义软件定义的根本任务是确定软件系统的工程需求,也就是要搞清“做什么。软件定义过程可通过软件系统的可行性研究和需求分析两个阶段来完成。1 .可行性研究 本阶段的任务是根据用户提出的工程工程的性质、目标和规模,进一步了解用户的要求及现有的环境及条件,从技术、经济和社会等多方面研究并论证该工程的可行性。即
16、该工程是否值得去解决,是否存在可行的解决方法。 此时,系统分析人员应在用户的配合下对用户的要求和现有的环境进行深入调查并写出调研报告。进而进行可行性论证。可行性论证包括经济可行性、技术可行性、操作可行性、法律可行性等。在此基础上还要制定初步的工程方案,包括需要的软硬件资源、定义任务、风险分析、本钱/效益分析以及进度安排等。 可行性研究的结果将是使用部门负责人做出是否继续进行该工程决定的重要依据。2 .需求分析D需求分析的任务需求分析的任务是确定待开发的软件系统“做什么。具体任务包括确定软件系统的功能需求、性能需求和运行环境约束,编制软件需求规格说明书、软件系统的验收测试准则和初步的用户手册。2
17、需求分析的实现途径软件系统需求一般由用户提出。系统分析员和开发人员在需求分析阶段必须与用户反复讨论、协商,充分交流信息,并用某种方法和工具构建软件系统的逻辑模型。为了使开发方与用户对待开发软件系统达成一致的理解,必须建立相应的需求文档。有时对大型、复杂的软件系统的主要功能、接口、人机界面等还要进行模拟或建造原型,以便向用户和开发方展示待开发软件系统的主要特征。确定软件需求的过程有时需要反复屡次,最终得到用户和开发者确实认。3)需求分析的阶段成果需求分析阶段的主要成果有软件需求规格说明、软件验收测试方案和准则、初步的用户手册等。其中,软件需求规格说明(SoftwareRequirementsS
18、pecification,即SRS),是一个关键性的文档。1.3.2 软件开发 软件开发过程由概要设计、详细设计、实现(即编码与单元测试)、组装测试、验收测试共5个阶段组成。 其中,概要设计和详细设计统称为设计;编码即编程;单元测试、组装测试和验收测试统称为测试。 开发者通常可提出多种设计方案,并对各种方案在功能、性能、本钱、进度等方面进行比较和折衷,从中选出一种“最正确方案。1.3.3 软件的使用与维护1 .软件使用与维护阶段任务:通过各种维护活动使软件系统持久地满足用户的需求。每项维护活动实质上都是一次压缩和简化了的软件定义和软件开发过程。都要经历提出维护要求、分析维护要求、提出维护方案、
19、审批维护方案、确定维护方案、修改软件设计、修改程序、测试程序、评审、验收等步骤。1 .软件使用与维护阶段应当指出,软件在使用的过程中,应及时收集被发现的软件错误,并定期撰写“软件问题报告;而每一项维护活动都应该准确地记录下来,并作为正式的文档资料保存。据统计,软件维护人员为了分析和理解原软件系统所花费的工作量约占整个维护工作量的60%以上。在软件开发的过程中应重视对软件可维护性的支持。2 .退役B1-3-2软淋啸与物用岫层次对殷系1.4软件开发模型 软件开发模型(又称为软件生存周期模型)一软件工程开发和维护的总体过程思路的框架。 它指出了软件开发过程各阶段之间的关系和顺序,是软件开发过程的概括
20、它为软件开发过程提供原则和方法,并为软件工程管理提供里程碑和进度表。因此,软件开发模型也是软件工程的重要内容。 软件开发模型的几种类型: 以软件需求完全确定为基础的瀑布模型; 在开发初期仅给出根本需求的渐进式模型,如原型模型、螺旋模型、喷泉模型等; 以形式化开发方法为基础的变换模型、基于四代技术的模型; 基于知识的智能模型等等。在实际开发时,应根据工程的特点和现有的条件选取适宜的模型,也可以把几种模型组合起来使用以便充分利用各模型的优点。1. 4.1瀑布模型瀑布模型(waterfallmodel)是由W.ROyCe于1970年提出来的。又称为软件生存周期模型。瀑布模型严格按照软件生存周期各个
21、阶段来进行开发,上一阶段的输出即是下一阶段的输入,并强调每一阶段的严格性。它规定了各阶段的任务和应提交的成果及文档,每一阶段的任务完成后,都必须对其阶段性产品(主要是文档)进行评审,通过后才能开始下一阶段的工作。因止匕它是一种以文档作为驱动的模型。借求分析IM洌1I4,I;三yIIBi-4-i带反蕾娜布皿瀑布模型优点:提供了软件开发的根本框架,有利于大型软件开发过程中人员的组织、管理,有利于软件开发方法和工具的研究与使用,因此,在软件工程中占有重要的地位。瀑布模型缺点1)在软件开发的初期阶段就要求做出正确、全面、完整的需求分析对许多应用软件来说是极其困难的。2)在需求分析阶段,当需求确定后,无
22、法及时验证需求是否正确、完整。3)作为整体开发的瀑布模型,由于不支持产品的演化,缺乏灵活性,对开发过程中很难发现的错误,只有在最终产品运行时才能暴露出来,从而使软件产品难以维护。瀑布模型适应场合瀑布模型一般适用于功能、性能明确、完整、无重大变化的软件系统的开发。例如操作系统、编译系统、数据库管理系统等系统软件的开发。应用有一定的局限性。1.4.2 原型模型原型模型(prototypingmodel)的根本框架是软件开发人员根据用户提出的软件根本需求快速开发一个原型,以便向用户展示软件系统应有的局部或全部功能和性能,在征求用户对原型的评价意见后,进一步使需求精确化、完全化,并据此改良、完善原型,
23、如此迭代,直到软件开发人员和用户都确认软件系统的需求并达成一致的理解为止。软件需求确定后,便可进行设计,编码、测试等以后的各个开发步骤。快速原型的开发途径有三种:O仅模拟软件系统的人机界面和人机交互方式。2)开发一个工作模型,实现软件系统中重要的或容易产生误解的功能。3)利用一个或几个类似的正在运行的软件向用户展示软件需求中的局部或全部功能。总之,建造原型应尽量采用相应的软件工具和环境,并尽量采用软件重用技术,在运行效率方面可做出让步,以便尽快提供。同时,原型应充分展示软件系统的可见局部,如人机界面、数据的输入方式和输出格式等。原型模型的适应场合原型模型比瀑布模型更符合人们认识事物的过程和规律
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 如何 理解 软件 软件工程
