软件工程张海藩课后习题答案.docx
《软件工程张海藩课后习题答案.docx》由会员分享,可在线阅读,更多相关《软件工程张海藩课后习题答案.docx(35页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、软件工程导论课后习题答案第一章软件工程概论1.什么是软件危机?软件危机是指在计算机软件的开发和维护过程中所遇到的一系列严 峻问题。这些问题表现在以下几个方面:(1)用户对开发出的软件很难满足。(2)软件产品的质量往往靠不住。(3)一般软件很难维护。(4)软件生产效率很低。(5)软件开发成本越来越大。(6)软件成本与开发进度难以估计。(7)软件技术的发展远远满足不了计算机应用的普与与深化的须 要。2.为什么会产生软件危机?(1)开发人员方面,对软件产品缺乏正确相识,没有真正理解软件 产品是一个完整的配置组成。造成开发中制定安排盲目、编程草率,不考 虑维护工作的必要性。(2)软件本身方面,对于计算
2、机系统来说,软件是逻辑部件,软件 开发过程没有统一的、公认的方法论和规范指导,造成软件维护困难。(3)尤其是随着软件规模越来越大,困难程度越来越高,原有软件开 发方式效率不高、质量不能保证、成本过高、研制周期不易估计、维护困 难等一系列问题更为突出,技术的发展已经远远不能适应社会需求。列前面的符合该等级房条件的申请者;从空房文件中删掉这个房号的信 息,并从分房队列中删掉该申请单,再把此房号的信息和住户信息一起写 到住房文件中,输出住房安排单给住户,同时计算房租,并将算出的房租 写到房租文件中。(2)假如是退房申请,则从住房文件和房租文件中删除有关信息,再把此房号的信息写到空房文件中。(3)假如
3、是调房申请,则依据申请者的状况确定其住房等级,然后 在空房文件中查找属于该等级的空房,退掉原住房,再进行与分房类似的 处理。(4)住户可以向系统查询目前分房的阀值分数,居住某类房屋的条 件,某房号的单位面积与房租等信息。房产科可以要求系统打印住房状况 的统计表,或更改某类房屋的居住条件、单位面积和房租等。用数据流图描绘该系统的功能需求;在数据字典中给出主要的数据 流、文件和加工说明。参考第四章4. 5应用举例教案之二分析。第四章总体设计习题答案1 .系统设计包括哪两个阶段?系统设计包括总体设计与具体设计两个阶段。2 .总体设计的主要任务是什么?总体设计的主要任务是完成软件结构的设计,确定系统的
4、模块与其模块之间的关系。3 .什么是模块?模块具有哪几个特征?总体设计主要考虑什么特征?模块是数据说明、可执行语句等程序对象的集合,可以单独命名且可 通过名字来访问。模块具有输入和输出(参数传递)、功能、内部数据结构(局部变量)和 程序代码四个特性。概要设计主要考虑输入、输出(参数传递)和功能两个特性。4 .什么是模块化?模块设计的准则?模块化是按规定的原则将一个大型软件划分为一个个较小的、相对独 立但又相关的模块。模块设计的准则:(1)改进软件结构,提高模块独立性:在对初步模块进行合并、分 解和移动的分析、精化过程中力求提高模块的内聚,降低藕合。(2)模块大小要适中:大约50行语句的代码,过
5、大的模块应分解以 提高理解性和可维护性;过小的模块,合并到上级模块中。(3)软件结构图的深度、宽度、扇入和扇出要适当。一般模块的调 用个数不要超过5个。(4)尽量降低模块接口的困难程度;(5)设计单入口、单出口的模块。(6)模块的作用域应在限制域之内。5 .变换型数据流由哪几部分组成?变换型结构由三部分组成:传入路径、变换(加工)中心和传出路径。6 .变换分析设计的步骤?(1)区分传入、传出和变换中心三部分,划分DFD图的分界线;(2)完成第一级分解:建立初始SC图的框架;(3)完成其次级分解:分解SC图的各个分支;(4)对初始结构图依据设计准则进行精化与改进。7 .事务型数据流由哪几部分组成
6、?事务型结构由至少一条接受路径、一个事务中心与若干条动作路径组 成。8 .事务分析设计的步骤?(1)在DFD图中确定事务中心、接收部分(包含全部接收路径)和发 送部分(包含全部动作路径);(2)画出SC图框架,把DFD图的三部分分?quot;映射为事务限制模 块,接收模块和动作发送模块.一般得到SC图的顶层和第一层(假如第一层 简洁可以并入顶层);(3)分解和细化接收分支和动作分支,完成初始的SC图;(4)对初始结构图依据设计准则进行精化与改进。9 .比较层次方框图与结构图是的异同?(1)层次方框图描绘数据的层次结构,结构图描绘的是软件结构。(2)二者都采纳多层次矩形框树形结构。层次方框图的顶
7、层矩形框 代表完整的数据结构,下面各层矩形框依次代表上个框数据的子集;结 构图 是在层次图的每一个方框内注明模块的名字或主要功能,方框之 间的直线表示模块的调用关系,用带注解的箭头表示模块调用过程中传递 的信息。10 .欲开发一个银行的活期存取款业务的处理系统:储户将填好的存/取款 单和存折交给银行工作人员,然后由系统作以下处理;(1)业务分类处理:系统首先依据储户所填的存/取款单,确定本次业 务的性质,并将存/取款单和存折交下一步处理;(2)存款处理:系统将存款单上的存款金额分别记录在存折和帐目文 件中,并将现金存入现金库;最终将存折还给储户;(3)取款处理:系统将取款单上的取款金额分别记录
8、在存折和帐目文 件中,并从现金库提取现金;最终将现金和存折还给储户。绘制该系统的数据流图和软件结构图。顶层一层二层软件结构图第五章习题参考答案一.回答问题1 .具体设计的目的?为软件结构图(SC图或HC图)中的每一个模块确定采纳的算法和块内数据 结构,用某种选定的表达工具给出清晰的描述.2 .具体设计的主要任务?编写软件的“具体设计说明书” .软件人员要完成的工作:(1) 为每一个模块确定采纳的算法,选择某种适当的工具表达算法 的过程,写出模块的具体过程描述.(2) 确定每一模块运用的数据结构.(3) 确定模块结构的细微环节,包括对系统外部的接口和用户界面,对 系统内部其它模块的接口,以与关于
9、模块输入数据、输出数据与局部数据 的全部细微环节.(4) 为每一个模块设计出一组测试用例,以便在编码阶段对模块代码(即程序)进行预定的测试.3 .结构化程序设计的基本原则?在具体设计中全部模块都运用单入口、单出口的依次、选择、循环三种基 本限制结构.4 .比较面对数据流和面对数据结构两类设计方法的异同?相同点:(1) 遵守结构程序设计“由顶向下”逐步细化的原则,并以其为共同的基础;(2) 均听从“程序结构必需适应问题结构”的基本原则,各自拥有从 问题结构(包括数据结构)导出程序结构的一组映射规则。不同点:(1) 面对数据流的设计以数据流图为基础,在分析阶段用DFD表示软 件的逻辑模型,在设计阶
10、段按数据流类型,将数据流图转换为软件结构。 面对数据结构的设计以数据结构为基础,从问题的数据结构动身导出它的 程序结构。(2) 面对数据流的设计的最终目标是软件的最终SC图,面对数据结构的设计的最终目标是程序的过程性描述。5 .比较Jackson方法和LCP方法的异同?Jackson与LCP设计方法都是以数据结构为动身点,以程序的过程描述为最终目标,设计步骤基本相像。它们的主要差别是:运用不同的表达工具,其中LCP方法中的表达工具Warnier图比Jackson设计方法中的表达工具Jackson图有更大的通用性;(2) Jackson方法的步骤和指导原则有肯定的敏捷性,而LCP设计方法则更加严
11、密。6 .具体设计的描述工具应具备什么功能?无论哪类描述工具不仅要具有描述设计过程,如限制流程、处理功能、数 据组织与其它方面的细微环节的实力,而且在编码阶段能够干脆将它翻译 为用程序设计语言书写的源程序。二.给出一组数从小到大的排序算法,分别用下列工具描述其具体过程:(1) (1)流程图;(2)NS 图;(3)PAD 图;(4)PDL 语言。PDL语言略三.依据后面给出“卡片的分类与统计”项目说明,完成下列工作:(1)用Jackson图表示输入与输出数据结构,找出它们之间的对应单元;(2)画出用Jackson图表示的程序结构;(3)列出程序所需用的操作,并加到上一步画出的程序结构图上;(4)
12、用Jackson伪代码写出程序的过程表示。输入卡片分析程序。一叠输入卡片按内容分为KI、K2、K3三类,卡片的排 列规则是:以K1卡始,以K2卡终。起始卡之前属前置部分,不含K1卡;起 始卡与终了卡之间属分批部分,不含K2卡。如图:试用Jackson方法编一程序,要求依次完成下列分析工作:统计起始卡前卡片的张数,存入A;打印起始卡的内容;统计起始卡后出现的K1卡和K3卡总批数,存入B;统计起始卡后出现的K1卡的张数,存入C;统计起始卡后出现的K3卡的批数,存入D;打印终了卡的内容;打印A、B、C、D四个统计值。程序的过程表示与伪代码略第六章习题参考答案1.编码的任务?运用选定的程序设计语言,把
13、模块的过程性描述翻译为用语言书写的源程 序(源代码)。2. 对源程序基本要求?源程序要求:正确牢靠、简明清晰、效率高。(1) 源程序的正确性是对程序质量的最基本要求;(2) 源程序的简明清晰,便于验证源代码和模块规格说明的一样性,简洁进行测试和维护;(3) 对于大多数模块,编码时应当把简明清晰放在第一位;(4) 除了编码阶段产生源代码外,在测试阶段也须要编写一些测试程序,用于对软件的测试。3. 程序设计语言的特点?(1) 名字说明:程序中运用对象的名字,能为编译程序所检查和识别;(2) 类型说明:定义对象的类型,确定该对象的运用方式;(3) 初始化:为变量供应适当的初始值或由系统给变量赋一特殊
14、的表明未初始化的值;(4) 对象的局部性:程序中真正须要的那部分才能访问的对象;(5) 程序模块:限制程序对象的名字;(6) 循环限制结构:如FOR语句、WHILE-DO语句、REPEAT-UNTIL语句等;(7) 分支限制结构:如IF语句、CASE语句等;(8) 异样处理:为程序运行过程中发生的错误和意外事务供应检测和 处理上的帮助;(9) 独立编译:能分别编译各个程序单元。4. 选择程序设计语言须要考虑的因素?(1) 选择用户熟识、便于用户维护的语言。(2) 选择目标系统的环境中可以供应的编译程序所能选用的语言。(3) 选择可以得到的软件工具,能支持程序开发中可以利用的语言。(4) 依据工
15、程规模的大小、目标系统应用范围,照实时应用选择Ada语言或汇编语言,系统软件开发选择C语言或汇编语言,软件开发中 若含有大量数据操作则选择SQL、dBASE等数据库语言等。(5) 选择程序员熟识的语言。(6) 选择标准化程度高、程序可移植性好的语言。(7) 依据算法与计算的困难性、数据结构的困难性选择。如对于系统程序和结构困难的应用程序,选择支持数组、记录(或结构)与指针动 态数据结构的Pascal语言或C语言。(8) 依据实时要求系统须要的响应速度和效率选择相应的语言。5. 编码风格的指导原则。(1) 源程序:包括适当的标识符、适当的注解、程序清单的合理布局与清晰;(2) 数据说明:数据结构
16、或数据类型的说明次序标准化;变量名称尽量有意义;对困难的数据结构在注解中要说明在程序设计中实现这个 数据结构的方法。(3) 语句的构造简洁明白:不要为节约空间将多个语句写在同一行;尽量避开困难的条件与“非”条件的测试;避开大量运用循环嵌套和 条件嵌套;括号的运用是为了使逻辑表达式和算术表达式的运算依次清晰 直观。(4) 效率:考虑程序运行的时间存储器效率、输入/输出的效率; 在处理程序正确性、清晰与效率之间的关系时先求程序正确后求快;先求 清晰后求快;保持程序简洁以求快;书写清晰,不为“效率”牺牲清晰。6. 第四代语言(4GL)应具备哪些的特征?(1) 具有很强的数据管理实力,能对数据库进行有
17、效的存取、查询和其它有关操作;(2) 能供应一组高效的、非过程化的吩咐,组成语言的基本语句,编程时用户只需用这些吩咐说明“做什么”,不必描述实现的细微环节;(3) 能满足多功能、一体化的要求。为此,语言中除必需含有限制程序逻辑与实现数据库操作的语句外,还应包括生成与处理报表、表格、 图形,以与实现数据运算和分析统计功能的各种语句,共同构成一个一体 化的语言,以适应多种应用开发的须要。第七章 习题参考答案3 .怎样克服软件危机?(1)充分汲取和借鉴人类长期以来从事各种工程项目中积累的行之 有效的有效原理、概念、技术与方法,特殊是吸取几十年来人类从事计算 机硬件探讨和开发的阅历教训。在开发软件的过
18、程中努力作到良好的组 织,严格的管理,相互友好的协作。(2)推广在实践中总结出来的开发软件的胜利的技术和方法,并探 讨更好、更有效的技术和方法,尽快克服在计算机系统早期发展阶段形成 的一些错误概念和作法。(3)依据不同的应用领域,开发更好的软件工具并运用这些工具。 将软件开发各个阶段运用的软件工具集合成一个整体,形成一个很好的软 件开发支环环境。总之为了解决软件危机,既要有技术措施(方法和工具),又要有必要的组 织管理措施。4 .构成软件项目的最终产品:应用程序、系统程序、面对用户的文档资料和面对开发者的文档资料。5 .什么是软件生存周期?软件生存周期是指从软件定义、开发、运用、维护到淘汰的全
19、过程。6 .软件生存周期为什么划分成阶段?(1)任何一个阶段的具体任务不仅独立,而且简洁,便于不同人员 分工协作,从而降低整个软件开发工作的困难程度。(2)可以降低每个阶段任务的困难程度,简化不同阶段的联系,有利于工程的组织管理,也便于采纳良好的技术方法。1 .软件测试的基本任务?软件测试是依据特定的规则,发觉软件错误的过程;好的测试方案是尽可 能发觉迄今尚未发觉错误的测试;胜利的测试方案是发觉迄今尚未发觉错 误的测试;2 .测试与调试的主要区分?(1) 测试从一个侧面证明程序员的失败;调试证明程序员的正确;(2) 测试从已知条件起先,运用预先定义的程序,且有预知的结果, 不行预见的仅是程序是
20、否通过测试;调试从不行知内部条件起先,除统计 性调试外,结果是不行预见的;(3) 测试有安排并且要进行测试设计;调试不受时间约束;(4) 测试是发觉错误、改正错误、重新测试的过程;调试是一个推理的过程;(5) 测试执行是有规程的;调试执行要求程序员进行必要的推理;(6) 测试由独立的测试组在不了解软件设计的件下完成;调试由了解具体设计的程序员完成;(7) 大多数测试的执行和设计可由工具支持;调试用的工具主要是调试器。3 .人工复审的方式和作用?人工复审的方式:代码会审、走查和排练和办公桌检查;人工复审的作用:检查程序的静态错误。4 .什么是黑盒测试?黑盒测试主要采纳的技术有哪些? 黑盒测试也称
21、为功能测试,它着眼于程序的外部特征,而不考虑程序的内 部逻辑结构。测试者把被测程序看成一个黑盒,不用关切程序的内部结构。 黑盒测试是在程序接口处进行测试,它只检查程序功能是否能依据规格说 明书的规定正常运用,程序是否能适当地接收输入数据产生正确的输出信 息,并且保持外部信息(如数据库或文件)的完整性。黑盒测试主要采纳的技术有:等价分类法、边沿值分析法、错误推想法和 因果图等技术。5 .什么是白盒测试?白盒测试主要采纳的技术有哪些?测试者了解被测程序的内部结构和处理过程,对程序的全部逻辑路径进行 测试,在不同点检查程序状态,确定实际状态与预期状态是否一样。白盒测试主要采纳的技术有:路径测试技术和
22、事务处理流程技术,对包含 有大量逻辑推断或条件组合的程序采纳基于逻辑的测试技术。6 .路径测试技术中几种主要覆盖的含义?举例说明?语句覆盖:至少执行程序中全部语句一次。判定覆盖:使被测程序中的每一个分支至少执行一次。故也称为分支覆盖。条件覆盖:执行全部可能的穿过程序的限制路流程。条件组合测试:设计足够的测试用例,使每个判定中的全部可能条件取值 组合至少执行一次。(例略)7 .等价分类法的测试技术采纳的一般方法?举例说明?(1) (1)为每个等价类编号;(2) (2)设计一个新的测试方案,以尽可能多的覆盖尚未被覆盖的有效等价类,重复这一步骤,直到全部有效等价类被覆盖为止。(3) (3)设计一个新
23、的测试方案,使它覆盖一个尚未被覆盖的无效等价类,重复这一步骤,直到全部无效等价类被覆盖为止。(例略)8 .软件测试的一般步骤?单元测试、子系统测试、系统测试、验收测试、平行测试。9 .比较集成试的两种方式的优劣?非渐增式测试方式:分别测试模块,再把全部模块按设计要求放在一起组 成所要的程序。该方法编写测试软件工作量大,模块间的接口错误发觉得 晚,错误定位较难诊断,总体测试有的错误简洁漏掉,测试时间相对较少, 可以并行测试全部模块,能充分利用人力,加快工程进度。渐增式测试方式:把下一个要测试的模块,同已经测试好的那些模块结合 起来进行测试。该方法利用已测试过的模块作测试软件,开销小,较早发 觉模
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 软件工程 张海藩 课后 习题 答案
限制150内