软件工程课后答案_第1页
软件工程课后答案_第2页
软件工程课后答案_第3页
软件工程课后答案_第4页
软件工程课后答案_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

/第一章1.1什么是计算机软件?软件的特点是什么?计算机软件是指计算机系统中的程序及其文档软件的特点:软件是一种逻辑实体,而不是有形的系统元件,其开发成本和进度难以精确地估算。软件是被开发的或被设计的,没有明显的制造过程,一旦开发成功,只需复制即可,但其维护的工作量大。软件的运用没有硬件那样的机械磨损和老化问题。1.2简述软件的分类,并举例说明系统软件系统软件居于计算机系统中最接近硬件的一层,其他软件一般都通过系统软件发挥作用。例如:编译软件、操作系统。支撑软件支撑软件是支撑软件的开发和维护的软件。例如:数据库管理系统、网络软件、软件工具、软件开发环境。应用软件应用软件是特定应用领域专用的软件。例如:工程/科学计算机软件、嵌入式软件、产品线软件、Web应用软件、人工智能软件。 1.3简述软件语言的分类,并举例说明。需求定义语言是用于书写软件需求定义的语言。例如:PSL/PSA。功能性语言是用于书写软件功能规约的语言,通常又称为功能规约语言。例如:广谱语言、Z语言。设计性语言是用于书写软件设计规约的语言。例如:PDL。实现性语言也称为程序设计语言,是用于书写计算机程序的语言。例如:C、java、PROLOG、FORTRAN、COBOL、Modula。文档语言是用于书写软件文档的语言。通常用自然语言或半形式化语言书写。1.4什么是软件工程? 软件工程是应用计算机科学、数学及管理科学等原理,开发软件的工程。软件工程借鉴传统工程的原则、方法,以提高质量、降低成本为目的。1.5简述软件工程的基本原则。 软件工程原则包括围绕工程设计、工程支持和工程管理所提出的以下4条基本原则。选取适宜的开发模型必需相识需求定义的易变性,接受适宜的开发模型,保证软件产品满意用户的要求。接受合适的设计方法合适的设计方法有助于这些特征的实现,以达到软件工程的目标。供应高质量的工程支撑软件工程项目的质量和开销干脆取决于对软件工程所供应的支撑质量和效用。重视软件工程的管理仅当软件过程予以有效管理时,才能实现有效的软件工程。1.6软件工程生存周期分哪几个阶段?分别简述各个阶段的任务。 1. 计算机系统工程计算机系统工程的任务是确定待开发软件的总体要求和范围,以及该软件和其他计算机系统元素之间的关系,进行成本估算,作出进度支配,并进行可行性分析。 2. 需求分析需求分析主要解决待开发软件要“做什么”的问题,确定软件的功能、性能、数据、界面等要求,生成软件需求规约(也称软件需求规格说明)。3. 设计系统设计的任务是设计软件系统的体系结构,详细设计的任务是设计各个组成成分的实现微小环节,包括局部数据结构和算法。 4. 编码 编码阶段的任务是用某种程序设计语言,将设计的结果转换为可执行的程序代码。测试测试阶段的任务是发觉并订正软件中的错误和缺陷。1.7简述CMM的5个等级。 1. 初始级 2. 可重复级 3. 已定义级 4. 已管理级 5. 优化级1.8简述CMMI的连续式模型和阶段式模型。 1.阶段式模型的结构类同于软件CMM,它关注组织的成熟度,CMMI-SE/SW/IPPD1.1版中有5个成熟度等级:初始的、已管理的、已定义的、定量管理的、优化的。 2.连续式模型关注每个过程域的实力,CMMI中包括6个过程域实力等级:未完成的、已执行的、已管理的、已定义的、定量管理的、优化的。1.9简述各类软件过程模型的特点。1. 瀑布模型:上一阶段的活动完成并经过评审才能起先下一阶段的活动,接受上一阶段活动的结果作为本阶段活动的输入,依据上一阶段活动的结果实施本阶段应完成的活动,对本阶段的活动进行评审。2. 演化模型:从结构初始的原型动身,逐步将其演化成最终软件产品的过程。演化模型特别适用于对软件需求缺乏精确相识的状况。3. 增量模型:将软件的开发过程分为若干个日程时间交织的线性序列,融合了瀑布模型的基本成分(重复地应用)和演化模型的迭代特征,特别适用于需求经常发生变更的软件开发。4. 原型模型:开发人员和用户在“原型”上达成一样,缩短了开发周期,加快了工程进度,降低成本。5. 螺旋模型:将原型实现的迭代特征和瀑布模型中限制的和系统化的方面结合起来,不仅体现了这两种模型的优点,而且增加了风险分析。6. 喷泉模型:各个阶段没有明显的界限,开发人员可以同步进行开发,可以提高软件项目开发效率,节约开发时间,适应于面对对象的软件开发过程。7. 基于构件的开发模型:利用预先包装的构件来构造应用系统。8. 形式化方法模型:易于发觉需求的歧义性、不完整性和不一样性,易于对分析模型、设计模型和程序进行验证。1.10灵敏软件开发的特点是什么?个体和交互赛过过程和工具可以工作的软件赛过四平八稳的文档客户合作赛过合同谈判响应变更赛过遵循支配1.11简述灵敏软件开发的价值观。 1.个人和交互高于过程和工具 2.可运行软件高于详尽的文档 3.和客户协作高于合同(契约)谈判 4.对变更刚好作出反应高于遵循支配1.12简述灵敏软件开发的原则。1.最优先的是通过尽早地和不断地交有价值的软件来使客户满意。2.即使到了开发的后期,也欢迎变更需求。3.以几周到几个月为周期,尽快、不断地发布可运行软件。4.在整个项目过程中,业务人员和开发人员必需每天一起工作。5.以主动向上的员工为中心建立项目组,赐予他们所须要的环境和支持,对他们的工作予以充分的信任。6.项目组内效率最高、最有效的信息传递方式是面对面的交谈。7.测量项目进展的首要依据是可运行的软件。8.灵敏过程提倡可持续的开发,项目发起者、开发者和用户应能长期保持恒定的速度。9.应时刻关注技术上的精益求精和好的设计,以增加灵敏性。10.简洁化是必不行少的,这是尽可能削减不必要工作的艺术。11.最好的构架、需求和设计出自于自我组织的团队。12.团队要定期反思怎样才能更有效,并据此调整自己的行为。1.13通过本章学习,请对灵敏软件开发作简要评价。 (略)1.14简述CASE工具和环境的重要性。 CASE已被证明可以加快开发速度,提高应用软件生产率并保证应用软件的牢靠品质。计算机专业人员利用计算机使他们的企业提高了效率,企业的各个部门通过运用计算机提高了生产率和效率,增加了企业的竞争力并使之带来了更多的利润。其次章2.1简述系统工程的任务识别用户的要求识别用户对基于计算机的系统的总体要求,标识系统的功能和性能范围,确定系统的功能、性能、约束和接口。系统建模和模拟一个基于计算机的系统通常可考虑建立以下模型:硬件系统模型、软件系统模型、人机接口模型、数据模型。成本估算及进度支配开发一个基于计算机的系统须要确定的资金投入和时间约束(交互日期),需进行成本估算,并作出进度支配。可行性分析主要从经济、技术、法律等方面分析所给出的解决方案是否可行。生成系统规格说明作为以后开发基于计算机的系统的依据。2.2基于计算机的系统由哪些元素组成?软件硬件人员数据库文档规程2.3简述可行性分析的任务经济可行性成本效益货币的时间价值投资的回收期纯收入技术可行性风险分析资源分析技术分析法律可行性方法的选择和折衷第三章3.1需求工程的重要性是什么? 可以确定客户需求帮助分析人员理解问题评估可行性协商合理的解决方法无歧义的规约方案、确认规约以及将规约转换到可运行的系统时的管理要求。3.2需求工程详细包括哪些步骤?每个步骤的详细任务是什么?需求获得:系统分析人员通过和用户的沟通、对现有系统的视察及对任务进行分析。需求分析和协商:分析每个需求和其他需求的关系以检查需求的一样性、重叠和遗漏的状况,并依据用户的需求对需求进行排序。系统建模:通过合适的工具和符号系统地描述需求。需求规约:给出对目标软件的各种需求。需求验证:对功能的正确性、完整性和清晰性以及其他需求赐予评价。需求管理:对需求工程全部相关活动的规约和限制。3.3一个系统分析员应当具备哪些思想素养和基本学问?请说明理由。能够娴熟地驾驭计算机硬、软件的专业学问,具有确定的系统开发阅历。擅进步行抽象的思维和创建性的思维,擅长把握抽象的概念,并把它们重新整理成为各种逻辑成分,并给出简明、清晰的描述。擅长从相互冲突或混淆的原始资料中抽出恰当的条目来。擅进步行调查探讨,能够很快学习用户的专业领域学问,理解用户的环境条件。能够倾听他人的看法,留意发挥其它人员的作用。具有良好的书面和口头沟通表达实力。3.4列出在制定需求获得策略时的3种主要考虑因素。功能需求。考虑系统要做什么,在何时做,在何时及如何修改或升级。性能需求。考虑软件开发的技术性指标。用户或人对因素。考虑用户的类型。3.5(略)3.6(略)3.7(略)3.8软件需求分析的操作性原则和需求工程的指导性原则是什么? 需求分析的操作性原则:必需能够表示和理解问题的信息域。必需能够定义软件将完成的功能。必需能够表示软件的行为(作为外部事务的结果)。必需划分描述数据、功能和行为的模型,从而可以分层次地揭示微小环节。分析过程应当从要素信息转移向微小环节信息需求工程的指导性原则:在起先建立分析模型之前应当先理解问题。假如问题没有很好理解就急于求成,经常会产生一个解决错误问题的完备的软件。强力举荐运用原型。这样做可以运用户了解将如何和计算机交互,而人们对软件质量的相识经常是基于对界面“友好性”的切身体会。记录每一个需求的起源和缘由。这是建立对用户要求的可追溯性的第一步。运用多个视图,建立系统的数据、功能和行为模型。这样做可帮助分析员从多方面分析和理解问题,削减遗漏,识别可能的不一样之处。给需求赐予优先级。因为过短的时限会削减实现全部软件需求的可能性。因此,对需求排定一个优先次序,标识哪些需求先实现,哪些需求后实现。留意消退歧义性。因为大多数需求都是以自然语言描述,存在叙述的歧义性问题造成遗漏和误会。接受正式的技术评审是发觉和消退歧义性的好方法。3.9软件需求规约主要包括哪些内容?引言信息描述功能描述行为描述检验标准参考书目附录3.10需求验证应当有哪些人参加?分析人员、用户、开发部门的管理者、软件设计、实现、测试的人员。第四章4.1简述软件设计阶段的基本任务。数据/类设计:将分析类模型变换成类的实现和软件实现所须要的数据结构。体系结构设计:定义了软件的整体结构,由软件部件、外部可见的属性和他们之间的关系组成。接口设计:描述了软件内部、软件和协作系统之间以及软件同人之间的通信方式。部件级设计:将软件体系结构的结构性元素变换为对软件部件的过过程性描述。4.2软件设计和软件质量的关系是怎么样的? 设计是在软件开发中形成质量的阶段,设计供应了可以用于质量评估的软件表示,是将用户需求精确地转化为完整的软件产品或系统的主要途径。4.3(略)4.4简述模块、模块化及模块化设计的概念。 模块是数据说明、可执行语句等程序对象的集合,是单独命名的,并且可以通过名字来访问的。 模块化是指把软件依据规定原则,划分为一个个较小的,相互独立的但又相互关联的部件。 模块化设计就是程序的编写不是起先就逐条录入计算机语句和指令,而是首先用主程序、子程序、子过程等框架把软件的主要结构和流程描述出来,并定义和调试好各个框架之间的输入、输出链接关系。4.5举例说明每种类型的模块耦合度和每种类型的模块内聚度。内容耦合:当一个模块干脆修改或操作另一个模块的数据,或者干脆转入另一个模块时就发生了内容耦合。此时,被修改的模块完全依靠于修改它的模块。假如发生下列情形,两个模块之间就发生了内容耦合:一个模块干脆访问另一个模块的内部数据一个模块不通过正常入口转到另一模块内部两个模块有一部分程序代码重叠(只可能出现在汇编语言中)一个模块有多个入口。公共耦合:若一组模块都访问同一个公共数据环境,则它们之间的耦合就称为公共耦合。公共的数据环境可以是全局数据结构、共享的通信区、内存的公共覆盖区等。外部耦合:一组模块都访问同一全局简洁变量而不是同一全局数据结构,而且不是通过参数表传递该全局变量的信息,则称之为外部耦合。限制耦合:假如一个模块通过传送开关、标记、名字等限制信息,明显地限制选择另一模块的功能,就是限制耦合。标记耦合:一组模块通过参数表传递记录信息,就是标记耦合。这个记录是某一数据结构的子结构,而不是简洁变量。其实传递的是这个数据结构的地址。数据耦合:一个模块访问另一个模块时,彼此之间是通过简洁数据参数(不是限制参数、公共数据结构或外部变量)来交换输入、输出信息的。非干脆耦合:两个模块之间没有干脆关系,它们之间的联系完全是通过主模块的限制和调用来实现的巧合内聚:讲几个模块中没有明确表现出独立功能的相同程序代码段独立出来建立的模块称巧合内聚模块。逻辑内聚:逻辑内聚是指完成一组逻辑相关任务的模块,调用该模块时,由传送给模块的限制性参数来确定该模块应执行哪一种功能。时间内聚:时间内聚是指一个模块中的全部任务必需在同一时间段内执行。过程内聚:过程内聚是指一个模块完成多个任务,这些任务必需指定的过程执行。通信内聚:通信内聚是指一个模块内全部处理元素都集中在某个数据结构的一块区域中。依次内聚:依次内聚是指一个模块完成多个功能,这些功能又必需依次执行功能内聚:功能内聚是指一个模块中各个部分都是为完成一项详细功能而协同工作,紧密联系不行分割。4.6耦合和软件可移植性的概念有何关系?耦合性是2个或多个模块相关的程度,可移植性是指软件从一个平台/环境转移到另一个平台/环境的难易程度。4.7描述信息隐藏概念,并探讨信息隐藏和模块独立两概念之间的关系。信息隐藏指在设计和确定模块时,使得一个模块内包含信息(过程或数据),对于不须要这些信息的其他模块来说,是不能访问的。在面对对象方法中,信息隐藏是通过对象的封装性来实现的。信息隐藏的概念和模块的独立性干脆相关4.8什么是模块的独立性?设计中为什么模块要独立?如何度量独立性?模块功能独立有何优点?模块独立性:模块独立性指每个模块只完成系统要求的独立的子功能,并且和其他模块的联系最少且接口简洁模块独立性是指模块内部各部分及模块间的关系的一种衡量标准,由内聚和耦合来度量。A.具有独立的模块的软件比较简洁开发出来。这是由于能够分割功能而且接口可以简化,当许多人分工合作开发同一个软件时,这个优点尤其重要。B.独立的模块比较简洁测试和维护。这是因为相对说来修改设计和程序须要的工作量比较小,错误传播范围小,须要扩充功能时能够"插入"模块。总之,模块独立是优秀设计的关键,而设计又是确定软件质量的关键环节。模块的独立程度可以由两个定性标准度量:内聚和耦合。A.具有独立的模块的软件比较简洁开发出来。这是由于能够分割功能而且接口可以简化,当许多人分工合作开发同一个软件时,这个优点尤其重要。B.独立的模块比较简洁测试和维护。4.9软件设计规约主要包括哪些内容?工作范围系统目标运行环境主要软件需求设计约束/限制体系结构设计数据流和限制流复审导出的程序结构功能和程序交叉索引数据设计数据对象和形成的数据结构文件和数据库结构:i.文件的逻辑结构;ii.文件逻辑记录描述;iii.访问方式全局数据文件/数据和程序交叉索引接口设计人机界面规格说明人机界面设计规则外部接口设计:i.外部数据接口;ii.外部系统或设备接口内部接口设计规则各部件的过程设计处理和算法描述接口描述设计语言(或其他)描述运用的部件内部程序逻辑描述注释/约束/限制运行设计运行部件组合运行限制运行时间出错处理设计出错处理信息出错处理对策:i.设置后备;ii.性能降级;iii.复原和再启动平安保密设计需求/设计交叉索引测试部分测试方针集成策略特别考虑特别注解附录第五章5.1简述数据流图的主要思想,概述运用数据流图进行需求分析的过程。 数据流图描述输入数据流到输出数据流的变换(即加工),用于对系统的功能建模。画出系统的输入和输出确定源和宿确定加工确定数据流顶层图通常没有文件画出系统内部确定加工确定数据流确定文件确定源和宿画出加工内部重复第3步,直至每个尚未分解的加工都足够简洁(即不必再分解)5.2分别接受数据流方法中的哪些技术来完成用户需求的精确化、一样化和完全化任务?父图和子图平衡数据守恒局部文件一个加工的输入数据流不能和该加工的输入数据流同名每个加工至少有一个输入数据流和一个输出数据流在整套分层数据流中,每个文件应至少有一个加工读该文件,有另一个加工写该文件。分层数据流图中得每个数据流和文件都必需命名(除了流入或流出文件的数据流),并且和数据字典一样。分层DFD中的每个基本加工(即不再分解子图的加工)都应有一个加工规约。5.3(略)5.4在数据流图中,可否将两个加工用一个数据流相连?可否将两个源用一个数据流相连?为什么? 两个加工可以干脆用数据流相连,两个源不能干脆用数据流相连。因为数据流由一组固定成分的数据组成。在DFD中,数据流的流向可以有以下几种:从一个加工刘向另一个加工,从加工流向文件(写文件),从文件流向加工(读文件),从源流向加工,从加工流向宿。5.5(略)5.6(略)5.7(略)5.8(略)5.9(略)第六章(略)第七章(略)第八章(略)第九章(略)第十章(略)第十一章11.1软件测试的目的是什么? 软件测试的目的是发觉软件中的错误和缺陷,并加以订正。11.2什么是白盒测试?什么是黑盒测试? 白盒测试又称结构测试,这种方法把测试对象看做一个透亮的盒子,测试人员依据程序内部的逻辑结构及有关信息设计测试用例,检查程序中全部逻辑路径是否都按预定的要求正确地工作。白盒测试主要用于对程序模块的测试。包括:程序模块中的全部独立路径至少执行一次。对全部逻辑判定的取值(“真”和“假”)都至少测试一次。在上下边界及可操作范围内运行全部循环测试内部数据结构的有效性等黑盒测试又称行为测试,这种方法吧测试对象看做一个黑盒子,测试人员完全不考虑程序内部的逻辑结构和内部特性,只依据程序的需求规格说明书,检查程序的功能是否符和它的功能需求。黑盒测试可用于各种测试,它试图发觉以下类型的错误:不正确或遗漏的功能接口错误,如输入输出参数的个数、类型等数据结构错误或外部信息(如外部数据库)访问错误性能错误初始化和终止错误11.3(略)11.4(略)11.5分别简述单元测试、集成测试、确认测试和系统测试的任务。单元测试:又称模块测试,着重对软件设计的最小单元——软件构件或模块进行验证。单元测试依据设计描述,对重要的限制路径进行测试,已发觉构建或模块内部的错误,通常接受白盒测试,并且多个构件或模块可以并行测试。单元测试的主要内容:接口、局部数据结构、边界条件、独立路径和错误处理路径。集成测试:也叫组装测试或联合测试。在单元测试的基础上,将全部模块依据要求(如依据结构图)组装成为子系统或系统,进行集成测试。运用黑盒测试方法测试集成的功能,并且对以前的集成进行回来测试。确认测试:经集成测试后,已经依据设计把全部的模块组装成一个完整的软件系统,接口错误也已经基本解除了,接着就应当进一步验证软件的有效性,这就是确认测试的任务,即软件的功能和性能如同用户所合理期盼的那样。系统测试:将已经确认的软件、计算机硬件、外设、网络等其他元素结合在一起,进行信息系统的各种组装测试和确认测试,系统测试是针对整个产品系统进行的测试,目的是验证系统是否满意了需求规格的定义,找出和需求规格不符或和之冲突的地方,从而提高更加完善的方案。11.6什么是α测试?什么是β测试?α测试时由一个用户在开发者的场所进行的测试,软件在开发者对用户的“指导下”进行测试。经过α测试后的软件成为β版软件。β测试是指软件开发公司组织各方面的典型用户在日常工作中实际运用β版本,并要求用户报告异样状况、提出指责看法,然后软件开发公司再对β版本进行改错和完善。11.7什么是回来测试? 回来测试就是对已经进行过的测试的子集的重新执行,以确保对程序的变更和修改,没有传播非有意的副作用。11.8简述边界值分析方法的作用。 长期的测试工作阅历告知我们,大量的错误时发生在输入或输出范围的边界上,而不是发生在输入输出范围的内部。因此针对各种边界状况设计测试用例,可以查出更多的错误。第十二章(略)第十三章13.1请探讨时软件维护成本居高不下的因素。如何尽可能降低这些因素的影响?软件的维护周期长;须要维护的软件往往没有文档、或文档资料严峻不足、或软件的变更未在相应的文档中反映出来;维护活动占用了其它软件开发可用的资源,使资源的利用率降低;一些修复或修改请求得不到刚好支配,使得客户满意率下降;维护的结果把一些新的潜在的错误引入软件,降低了软件质量;将软件人员抽调到维护工作中,使得其他软件开发过程受到干扰。确定质量管理目标和优先级;运用提高软件质量的技术和工具;选择可维护性高的程序设计语言;完善程序文档;进行质量保证审查13.2(略)13.3软件维护过程是如何进行的?为什么要进行软件可维护性分析?软件维护过程包括:建立维护组织;确定维护过程;保管维护记录;进行维护评价等四个阶段。可维护性是指理解、改正、调整和改进软件的难易程度。进行可维护性分析有利于做出正确的确定,进而实行相应的方法应对客户的需求,对的确不能或者没有进行维护的价值的软件坚决不进行维护,对于可以维护的软件来说,可维护性分析有助于我们了解软件状况,从而做出相应的维护措施13.4(略)13.5(略)13.6(略)13.7在重构和正向工程之间存在的微小不同是什么?重构是指在统一抽象级别上转换系统的描述形式;正向工程过程应用软件工程的原理、概念、技术和方法来重新开发某个现有的应用系统。从概念可以看出,重构是从一个系统环境转换到另一个系统环境,而正向工程则是重新开发,从零起先,没有确定基础的。13.8(略)第十四章14.1何谓软件项目管理?软件项目管理和传统项目管理的不同点和相同点?软件项目管理的对象是软件工程项目。它所涉及的范围覆盖了整个软件工程过程。为使软件项目开发获得成功,关键问题是必需对软件项目的工作范围、可能风险、须要资源(人、

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论