• 794.11 KB
  • 2022-04-22 11:38:41 发布

程导论》张海潘_第五版_清华_课后答案.pdf

  • 12页
  • 当前文档由用户上传发布,收益归属用户
  1. 1、本文档共5页,可阅读全部内容。
  2. 2、本文档内容版权归属内容提供方,所产生的收益全部归内容提供方所有。如果您对本文有版权争议,可选择认领,认领后既往收益都归您。
  3. 3、本文档由用户上传,本站不保证质量和数量令人满意,可能有诸多瑕疵,付费之前,请仔细先通过免费阅读内容等途径辨别内容交易风险。如存在严重挂羊头卖狗肉之情形,可联系本站下载客服投诉处理。
  4. 文档侵权举报电话:19940600175。
'爱答案习题答案课件资源网www.aidaan.cn第1页www.khdaw.com第一章软件工程方法学(3个要素):通常把软件生命周期全过程中使用的一整套技术方法的集合称为方法学,也称范型。三要素:方法、工具和过程。软件生命周期模型–瀑布模型:优点:1.可强迫开发员采用规范的方法2.严格地规定了每个阶段必须提交的文件3.要求每个阶段交出的所有产品都必须经过质量保证小组的仔细验证。–缺点:传统的瀑布模型过于理想化,是由文档驱动的。–快速原型模型:通过快速构建起一个可在计算机上运行的原型系统,让用户试用原型并收集用户反馈意见的方法,获取用户真正的需要。–增量模型:优点:能在较短时间内向用户提交可完成部分工作的产品;逐步增加产品功能可以使用户有较充实的时间学习和适应新产品,从而减少一个全新的软件可能给客户组织带来的冲击。–螺旋模型:优点:对可选方案和约束条件的强调有利于已有软件的重用;减少了过多测试;维护只是螺旋模型中另一个周期。n1-1什么是软件危机?是指在计算机软件的开发和维护过程中所遇到的一系列严重问题。.c1-2什么是软件工程?是指导计算机软件开发和维护的一门工程学科。an1-3简述结构化范型和面向对象范型的要点,并分析它们的优缺点。目前使用得最广泛的软件工程方法学(2种):da1.传统方法学:也称为生命周期方法学或结构化范型。ai优点:把软件生命周期划分成基干个阶段,每个阶段的任务相对独立,而且比较简单,便于不同人员分工协作,w.从而降低了整个软件开发过程的困难程度。缺点:当软件规模庞大时,或者对软件的需求是模糊的或会承受时间而变化的时候,开发出的软件往往不成功;而且维护起来仍然很困难。ww2.面向对象方法学:优点:降低了软件产品的复杂性;提高了软件的可理解性;简化了软件的开发和维护工作;网促进了软件重用。源1-4软件生命周期划分成哪些阶段软件生命周期(各阶段)软件生命周期由软件定义、软件开发和运行维护三个时期组成。资1.软件定义时期划分为三个阶段:问题定义、可行性研究和需求分析件2.开发时期:总体设计、详细设计、编码和单元测试、综合测试。课3.维护时期:主要任务是使软件持久地满足用户的需要。1-5什么是软件过程?它与软件工程方法学有何关系案?软件过程:是为了获得高质量软件所需要完成的一系列任务的框架,它规定了完成各项任务的工作步骤答软件工程方法学:通常把在软件生命周期全过程中使用的一整套技术方法的集合称为方法学,也称范型1-6传统“瀑布模型”的主要缺陷是什么?试说明改进的方法。题传统的瀑布模型过于理想化了。增加习“反馈环”案第二章可行性研究的目的:就是用最小的代价在尽可能短的时间内确定问题是否能够解决。可行性研究的任务:答1.进一步分析和澄清问题;2.导出系统的逻辑模型;3.从逻辑模型出发,提出若干种系统实现方案爱4.研究每种实现方案的可行性:技术上的可行性——使用现有的技术能实现这个系统吗?经济上的可行性——这个系统的经济效益能超过它的开发成本吗?(投资与效益)操作可行性——系统的操作方式在这个用户组织内行得通吗?社会、政策允许的可行性5.为每个可行的解决方案制定一个粗略的实现进度6.对以后的行动方针提出建议方法:1.系统流程图2.数据流图:(DFD)是一种图形化技术,它描绘信息流和数据从输入移动到输出的过程中所经受的变换。符号数据处理处理数据存储数据流源点www.khdaw.com第1页 爱答案习题答案课件资源网www.aidaan.cn第2页www.khdaw.com3.数据字典:是关于数据的信息的集合,也就是对数据流图中饮食的所有元素的定义的集合。数据流图与数据字典共同构成系统的逻辑模型。4.成本/效益分析5.数据流图–定货系统P32–习题2第2题P43(银行储蓄系统)–习题2第3题P43(机票预订系统)–习题2第4题P43(医院监护系统)D1患者安全范围患者安全n范围.c1123病人生理生理危机病产生警告警告信息an接受处理分析信息da护士信号信号人信息信事务信号aiw.生理信号ww病情报告网516源7时钟日期定时生更新日志产生病情要求定时处理资日志日志报告护士时间理信号件事务样数据数据课D1患者日志案答6.数据定义1、顺序+2、选择〔|〕3、重复下限{}上限–定货系统P39题–习题2第习5题P442-1应该从哪些方面研究目标系统的可行性案?技术上的可行性——使用现有的技术能实现这个系统吗?经济上的可行性答——这个系统的经济效益能超过它的开发成本吗?(投资与效益)操作可行性爱——系统的操作方式在这个用户组织内行得通吗?社会、政策允许的可行性2-2为方便储户,某银行拟开发计算机储蓄系统。储户填写的存款单或取款单由业务员键入系统,如果是存款,系统记录存款人姓名、住址、存款类型、存款日期、利率等信息,并印出存款单给储户;如果是取款,系统计算利息并印出利息清单给储户。请画出此系统的数据流图。www.khdaw.com第2页 爱答案习题答案课件资源网www.aidaan.cn第3页www.khdaw.com1.11.2打印存单记录存款信息存款信息存款单银行存款信息储户D1存款信息储户取款单存款信息n.c利息清单2.12.22.3存款计算利息打印利息an验证利息da清单信息值ai某航空公司拟开发一个机票预定系统。旅行社把预订机票的旅客信息(姓名、性别w.…等)输入进该系统,系统为旅客安排航班,印出取票通知和账单,旅客在飞机起飞的前一天凭取票通知和账单交款取票,系统核对无误即印ww出机票给旅客。网源取票通知2.1资2.2旅客机票打印机交款件票账单/票款信息课案订票信交款信机票答息息旅客题D1订票信息习航班信旅客信取票通知案息息答账单爱旅客1.1旅客1.2机票1.3旅行社信息录入信信息安排信息打印处处理息航班理事务2-3北京某高校可用的电话号码由以下几类:校内电话号码由4位数字组成,第一位数字不是零;校外电话又分为本市电话和外地电话两类,拨校外电话先拨0,若是本地电话再接着拨8位数字(固话第一位不是0)或11位数字(移动电话第一位为1);若是外地电话,则拨3位区码再拨8位电话号码(固话第一位不是0),或拨0再拨11位数字(移动电话第一位为1)。请用数据定义的方法,定义上述电话号码。电话号码=[校内号码|校外号码]校内号码=非0数字+3{数字}3www.khdaw.com第3页 爱答案习题答案课件资源网www.aidaan.cn第4页www.khdaw.com校外号码=0+[本地号码|外地号码]本地号码=[固话号码|手机号码]固话号码=非0数字+7{数字}7手机号码=1+10{数字}10外地号码=[外地固话号码|外地手机号码]外地固话号码=3{数字}3+固话号码外地手机号码=0+手机号码非0数字=[1|2|3|4|5|6|7|8|9]第三章需求分析的准则:1、必须并描述的信息域,根据这条准则应该建立数据模型。2、必须定义软件应完成的功能,这条准则要求建立功能模型。3、必须描述作为外部事件结果的软件行为,这条准则要求建立行为模型。4、必须对描述信息、功能和行为的模型进行分解,用层次的方式展示细节。需求分析的任务(P46)1、确定对系统的综合要求;2、分析系统的数据要求;3、导出系统的逻辑模型n;4、修正系统开发计划。.c方法an–实体-联系图教学管理系统P54da姓名性别职称姓名性别系aiw.教工号职务学号ww年级网源资件课案课程号课名答学时学分题习题习3第3题P63(银行储蓄系统)姓名住址案电话号码身份证号码名称地址电话号码答爱N储户存取款M储蓄所数额类型到期日利率密码www.khdaw.com第4页 爱答案习题答案课件资源网www.aidaan.cn第5页www.khdaw.com习题3第5题P63(医院监护系统)姓名住址电话号住院号姓名科室工作证NM病人监护护士n.c时间脉搏体温血压an心电图–数据流图da–状态转换图ai电话系统P57w.习题3第6题P63(复印机)ww排除卡纸故障网卡纸源资件do/警告课卡纸复印命令案复印闲置答完成复印命令题do/复印习发现缺纸缺纸案答do/警告爱装满纸第五章总体设计的任务划分出组成系统的物理元素——程序、文件、数据库、人工过程和文档等等设计软件的结构。也就是要确定系统中每个程序是由哪些模块组成的,以及这些模块相互间的关系。总体设计过程两个阶段1.系统设计阶段,确定系统的具体实现方案;2.结构设计阶段,确定软件结构。总体设计过程9个步骤1设想供选择的方案2选取合理的方案3推荐最佳方案4功能分解5设计软件结构6设计数据库7制定测试计划8书写文档9审查和审核www.khdaw.com第5页 爱答案习题答案课件资源网www.aidaan.cn第6页www.khdaw.com低耦合(5种类型)1.数据耦合:数据传递2.控制耦合:控制信息传递3.特征耦合:传过多的信息给被调用模块4.公共环境耦合:因全局变量,共享通信区5.内容耦合:诸如一个模块访问另一个模块内部高内聚(7种类型)功能内聚10分顺序内聚9分通信内聚7分过程内聚5分时间内聚3分逻辑内聚1分偶然内聚0分面向数据流的设计方法P95–变换流数字仪表板系统P96旋转信号读入确定旋转加速/信号信号数/秒减速箭头指示n(SPS)△SPS收集.c并求产生平均加速/减△SPS速显示下箭头an水平线da转换成转/分rpm上箭头燃料流量(rpm)ai传感器信号计算rpm里程w.英里读入并核实ww产生燃料流量计算里程mph和超速值显示超速值网计算mph发出gph源警告显示gph铃声计算资燃料警告铃声消耗件mphmpg课产生mph产生显示案mpg答显示mpg显示题mph显示习数字仪表板案控制答数据转换爱接收传感器驱动仪表板信号控制转换成计算计算计算计算显示显示显示发出警rpmgphmphmpg里程mphmpg里程报铃声读旋转读燃料确定加速/减速发光二极管信号流量加速/减速显示显示患者监护系统(参见习题2第4题)–事务流用户命令交互子系统(DFD)www.khdaw.com第6页 爱答案习题答案课件资源网www.aidaan.cn第7页www.khdaw.com格式化配用户系统参数数据原配置置命令数据建立配数据置文件读系统读用户数据配置信息命令配置命令格式化配置数据配置命令类型命令开/关数据分析处理命令A/D信息显示信息n激活/非活动系统.c和状态密码命令an显示信息读da检验信密码密码ai息w.四位数与文件中ww重试信息字密码比较检验信网检验信息过程源息资用户执行模块件SC图课案读用户命令命令处理答题习案系统设置现用/非现用密码处理控制器系统控制器答爱读系统建立配读用文件密码输出数据置文件密码比较密码控制器显示信息产生与状态无效信息机票预订系统(参见习题2第3题)www.khdaw.com第7页 爱答案习题答案课件资源网www.aidaan.cn第8页www.khdaw.com第六章结构程序设计概念P108–如果一个程序的代码块仅仅通过顺序、选择和循环这三种基本控制结构进行连接,而且每个代码块只有一个入口和一个出口,则称这个程序是结构化的结构程序设计3种概念类型P1091、经典的结构程序设计只允许使用顺序、IF-THEN-ELSE型分支和DO-WHILE型循环着三种基本控制结构2、扩展的结构程序设计还允许使用DO-CASE型多分支结构和DO-UNTIL型循环结构3、修正的结构程序设计还允许使用EXIT(或BREAK)结构方法1、人机界面设计2、过程设计的工具P1143、面向数据结构的设计方法——Jackson方法n4、程序复杂程度的定量度量P127.c–McCabe方法an根据程序控制流的复杂程度定量度量程序的复杂程度,这样度量出的结果称为程序的环形复杂度。可用三种方法之一来计算复杂性:da1.流图中区域的数量对应于环形的复杂度;ai2.流图G的环形复杂度V(G)=E-N+2,其中,E是流图中边的数量,w.N是流图中节点的数量;3.流图G的环形复杂度V(G)=P+1,其中,P是流图中判定节点的数量–Halstead方法ww程序流程图P114网–习题六第3题P131源开始画出下列伪程序的程序流程图和盒图START资IFpTHEN件FTWHILEqDO课PFENDDO案ELSE答GQFBLOCKTG题FN习ENDBLOCK案NENDIFSTOP答爱FPT结束QGFNwww.khdaw.com第8页 爱答案习题答案课件资源网www.aidaan.cn第9页www.khdaw.comPAD(问题分析)图判定表P117–行李托运费计算P118–讲课课时津贴计算12345某校制定了教师的讲课课时津贴标准。对于各种教授TFFF性质的讲座,无论教师是副教授FTFF什么职称,每课时津贴费一律是50元;而对于一讲师FFTF般的授课,则根据教师的助教FFFT职称来决定每课时津贴费:教授n30元,副教授讲座TFFFF25元,讲师20元,助教50×.c15元。30×anda25×ai20×w.15ww×判定树P118网–行李托运费计算P119源–讲课课时津贴计算资教授件30副教授25一般授课课案讲师20课时津贴答助教15讲座题50过程设计语言(PDL习Jackson设计方法的步骤(案5步)P122–实例P123–高考后将考生的基本情况文件(简称考生基本情况文件)和考生高考成绩文件(简称考分文件)合答爱并成一个新文件(简称考生新文件)。考生基本情况文件和考分文件都是由考生记录组成的。为简便起见,考生基本情况文件中的考生记录的内容包括:准考证号、姓名、通讯地址。考分文件中的考生记录的内容包括:准考证号和各门考分。合并后的考生新文件自然也是由考生记录组成,内容包括:准考证号、姓名、通讯地址和各门考分。考生情况文件考分文件考生新文件III考生记录*考生记录*考生记录*准考证号姓名通讯地址准考证号考分准考证号姓名通讯地址考分(a)输入数据结构(b)输出数据结构www.khdaw.com第9页 爱答案习题答案课件资源网www.aidaan.cn第10页www.khdaw.com操作:(1)停止;(2)打开两个输入文件;(3)建立输出文件。(4)从输入文件中各读一条记录。(5)生成一条新记录。(6)将新记录写入输出文件。(7)关闭全部文件。条件:I(1)文件结束。产生新文件234分析考生记录71nI(1)处理考生记录*.can产生准考证号产生姓名产生通讯地址产生考分564aida把操作和条件分配到程序结构图的适当位置w.将程序流程图映射为流图P127ww网11源资2件2,3课4,53案6答46题8习77案85答99爱10101111计算环形复杂度P127实例P128-129习题6第8题P1321:LOOP:DOWHILEZ>02:A=B+1IFA>103:THENX=A4:ELSEY=Z5:ENDIFwww.khdaw.com第10页 爱答案习题答案课件资源网www.aidaan.cn第11页1www.khdaw.comIFY<56:THENPRINTX,Y7:ELSEIFY=2THENGOTOLOOP28:ELSEC=3ENDIF9:ENDIF43G=H+RENDDO10:IFF>011:THENPRINTG512:ELSEPRINTR13:ENDIFnSTOP.cV(G)=66an7第七章软件测试的概念P140da目的:(1)测试是为了发现程序中的错误而执行程序的过程;ai8(2)好的测试方案是极可能发现迄今为止尚未发现的错误的测试方案;w.(3)成功的测试是发现了至今为止尚未发现的错误的测试。定义:为了发现程序中的错误而执行程序的过程。ww9测试绝不能证明程序是正确的网测试方法P141源–黑盒测试1把程序看作一个黑盒子,完全不考虑程序的内部结构和处理过程资102对程序接口进行测试,检查程序功能是否能按规格说明书的规定正件常使用;程序是否能适当地接受输入数据并产生正确的输出信息;课程序运行过程中能否保持外部信息的完整性12–白盒测试案111把程序堪称装在一个透明的白盒子里,测试者完全知道程序的结构处理算法答2按照程序内部的逻辑测试程序,检测程序中的主要执行通路是否都能按预定要求正确工作题13测试步骤P141习–单元测试:(模块测试)发现的往往是编码和详细设计的错误案–集成测试:着重测试模块的接口–系统测试:发现的往往是软件设计中的错误,也可能发现需要说明中的错误答爱–验收测试:(确认测试)往往发现需求说明书中的错误白盒测试逻辑覆盖–逻辑覆盖类型逻辑覆盖是以程序的内部逻辑结构为基础的测试用例设计技术,属于白盒测试。它要求测试人员十分清楚程序的逻辑结构,考虑的是测试用例对程序内部逻辑覆盖的程度。从覆盖源程序语句的详尽程度分析,大致有以下一些不同程度的覆盖标准:1语句覆盖2判定覆盖3条件覆盖4判定/条件覆盖5条件组合覆盖–实例P153–习题7第4题第(3)小题P174控制结构测试–基本路径测试P156www.khdaw.com第11页 爱答案习题答案课件资源网www.aidaan.cn第12页www.khdaw.com1:START路径1:1-2-3-4-6-7-9-11-12INPUT(A,B,C,D)路径2:1-2-5-6-7-9-11-122:IF(A>0)路径3:1-2-3-5-6-7-9-11-123:AND(B>0)路径4:1-2-3-4-6-7-8-9-11-124:THENX=A+B测试用例:路径4:1-2-3-4-6-7-8-10-11-125:ELSEX=A-B执行路径1(两个判定表达式之值全为真)6:ENDIF输入:A=1,B=1,C=2,D=2(任意)预期输出:X=2,Y=07:IFC>A执行路径2(两个判定表达式之值为假、真)8:OR(Dc5a+b<040应用范围;为了将来的维护工作。输a+b=041构成一般b+c>a6b+cb744a+c