收藏 分销(赏)

软件工程导论课后习题解答.doc

上传人:二*** 文档编号:4539310 上传时间:2024-09-27 格式:DOC 页数:43 大小:2.32MB
下载 相关 举报
软件工程导论课后习题解答.doc_第1页
第1页 / 共43页
亲,该文档总共43页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

1、. .第一章1-1什么是软件危机?答:是指在计算机软件的开发和维护过程中所遇到的一系列重问题。1-3什么是软件工程?答:是指导计算机软件开发和维护的一门工程学科。1-4简述构造化型和面向对象型的要点,并分析它们的优缺点。答:目前使用得最广泛的软件工程法学有2种:传统法学:也称为生命期法学或构造化型。优点:把软件生命期划分成假设干个阶段,每个阶段的任务相对独立,而且比较简单,便于不同人员分工协作,从而降低了整个软件开发过程的困难程度。缺点:当软件规模庞大时,或者对软件的需模糊的或会随着时间而变化的时候,开发出的软件往往不成功;而且维护起来仍然很困难。面向对象法学:优点:降低了软件产品的复杂性;提

2、高了软件的可理解性;简化了软件的开发和维护工作;促进了软件重用。1-5、根据历史数据可以做出如下的假设:对计算机存储容量的需求大致按下面公式描述的趋势逐年增加:M = 4080 e0.28(Y-1960)存储器的价格按下面公式描述的趋势逐年下降:P1 = 0.30.72Y-1974(美分/位)如果计算机字长为16位,那么存储器价格下降的趋势为:P2 = 0.0.72Y-1974(美元/字)在上列公式中Y代表年份,M是存储容量(字数),P1和P2代表价格。基于上述假设可以比较计算机硬件和软件本钱的变化趋势。要求计算:(1)在1985年对计算机存储容量的需求估计是多少?如果字长为16位,这个存储器

3、的价格是多少?(2)假设在1985年一名程序员每天可开发出10条指令,程序员的平均工资是每月4000美元。如果一条指令为一个字长,计算使存储器装满程序所需用的本钱。(3)假设在1995年存储器字长为32位,一名程序员每天可开发出30条指令,程序员的月平均工资为6000美元,重复(1)、(2)题。1在1985年对计算机存储容量的需求,估计是 4080 e0.28(1985-1960) 4080 e74474263(字)如果字长为16位,那么这个存储器的价格是 0. 0.721995-1974 73577679 5789(美元)2如果一条指令的长度为一个字,那么使存储器装满程序共需4474263条

4、指令。在1985年一名程序员每天可开发出10条指令,如果每月的20个工作日,那么每人每月可开发出10*20条指令。为了开发4474263条指令以装满存储器,需要的工作量是:4474263 / 200 22371(月)程序员的月平均工资是4000美元,开发出4474263条指令的本钱是22371 4000 89484000(美元)3在1995年对存储容量的需求估计为: 4080 e0.28(19951960) 73577679 (字)4080e9.8如果字长为32位,那么这个存储器的价格是: 0.003 32 0.721995-1974 73577679 7127(美元)如果一条指令为一个字长,

5、那么为使存储器装满程序共需73577679条指令。在1995年一名程序员每天可开发30条指令,每月可开发出600条指令,为了开发出可装满整个存储器的程序,需要的工作量为73577679 600 122629(人月)开发上述程序的本钱为:122629 6000 735776790(美元)1-6什么是软件过程?它与软件工程法学有关系?答:软件过程:是为了获得高质量软件所需要完成的一系列任务的框架,它规定了完成各项任务的工作步骤。软件工程法学:通常把在软件生命期全过程中使用的一整套技术法的集合称为法学,也称型1-7什么是软件生命期模型,试比较瀑布模型,快速原型模型,增量模型,和螺旋模型的优缺点,说明

6、每种模型的适用围。答:软件生命期由软件定义、软件开发和运行维护3个时期组成,每个时期又进一步划分成假设干个阶段。生命期模型规定了把生命期划分成哪些阶段及各个阶段的执行顺序,因此,也称为过程模型。瀑布模型的优点:1.可强迫开发人员采用规的法;2.格规定了每个阶段必须提交的文档;3.要求每个阶段交出的所有产品都必须经过质量保证小组的仔细验证。瀑布模型的缺点:1.在软件开发初期,指明用户全部需困难的;2.需求确定后,经过一段时间才得到软件最初版本;3.完全依赖规格说明,导致不能满足用户需求。适用中小型工程。快速原型模型的优点:1满足用户需求程度高;2用户的参与面广;3返工现象少。不适用大型软件的开发

7、适用于小型工程。增量模型的优点:1短期可以交付满足局部用户需求的功能产品;2逐步增加功能可以让用户去适应新产品;3开放式的软件可维护性比较好;4开场第一构件前,已经完成需求说明。增量模型的缺点:1对现有产品功能造成破坏;2意义上的矛盾适用于中型软件的开发螺旋模型的优点:1集成了瀑布模型、快速原型模型、增量模型的优点;2支持用户需求动态变化;3需求分析与软件实现严密联系相互依赖;4原型作为刑式的可执行的需求规格说明,即利用用户和开发人员共同理解,又可作为后续开发的根底;5为用户参与决策提供便;6提高目标软件的适应能力;7降低风险;8在大型软件开发过程中充分发挥优势。螺旋模型的缺点:1迭代次数影响

8、开发本钱,延迟提价时间;2找不到关键改进点,人才、物力、财力时间引起无谓消耗;3成于风险分析,败于风险分析。适用于部开发的大规模软件工程。1-8:为什么说喷泉模型叫好的表达了面向对象软件开发过程无缝和迭代的特性?答:因为使用面向对象法学开发软件时,各个阶段都使用统一的概念和表示符号,因此,整个开发过程都是吻合一致的,或者说是无缝连接的,这自然就很容易实现各个开发步骤的反复屡次迭代,到达认识的逐步深化,而喷泉模型的那么很好的表达了面向对象软件开发过程迭代和无缝的特性。1-9:试讨论Rational统一过程的优缺点答:优点:提高了团队生产力,在迭代的开发过程、需求管理、基于组建的体系构造、可视化软

9、件建模、验证软件质量及控制软件变更等面、针对所有关键的开发活动为每个开发成员提供了必要的准那么、模版和工具指导,并确保全体成员共享一样的知识根底。它简洁和清晰的过程构造,为开发过程提供较大的通用性。缺点:RUP只是一个开发过程,并没有涵盖软件过程的全部容,例如它缺少关于软件运行和支持等面的容,此外,它没有支持多工程的开发构造,这在一定程度上降低了在开发组织大围实现重用的可能性。1-10Rational统一过程主要适用于种工程?答:大型的需求不断变化的复杂软件系统工程1-11:说明敏捷过程的适用围答:适用于商业竞争环境下对小型工程提出的有限资源和有限开发时间的约束。1-12说明微软过程的适用围答

10、:适用于商业环境下具有有限资源和有限开发时间约束的工程的软件过程模式。第二章2-1在软件开发的早期阶段为什么要进展可行性分析研究?应该从哪些面研究目标系统的可行性?答:可行性分析是要进展一次大大压缩简化系统分析和设计过程,防止时间、资源、人力和金的浪费。技术上的可行性使用现有的技术能实现这个系统吗?经济上的可行性这个系统的经济效益能超过它的开发本钱吗?投资与效益操作可行性系统的操作式在这个用户组织行得通吗?社会、政策允的可行性2-2为便储户,某银行拟开发计算机储蓄系统。储户填写的存款单或取款单由业务员键入系统,如果是存款,系统记录存款人XX、住址、存款类型、存款日期、利率等信息,并印出存款单给

11、储户;如果是取款,系统计算利息并印出利息清单给储户。请画出此系统的数据流图。2-3为便旅客,某航空公司拟开发一个机票预定系统。旅行社把预订机票的旅客信息XX、性别、工作单位、XX、旅行时间、旅行目的地等输入进该系统,系统为旅客安排航班,印出取票通知和账单,旅客在飞机起飞的前一天凭取票通知和账单交款取票,系统核对无误即印出机票给旅客。请画出系统的数据流图。2-4目前住院病人主要由护士护理,这样做不仅需要大量护士,而且由于不能随时观察危险病人的病情变化,还可能会延误抢救时机。某医院打算开发一个以计算机为中心的患者监护系统,试写出问题定义,并且分析开发这个系统的可行性。医院对患者监护系统的根本要随时

12、承受每个病人的生理信号脉搏、体温、血压、心电图等,定时记录病人情况以及形成患者日志,当某个病人的生理信号超出医生规定的平安围时向值班护士发出警告信息,此外,护士在需要时还可以要求系统印出某个指定病人的病情报告。请画出系统的数据流图2-5某高校可用的由以下几类:校由4位数字组成,第一位数字不是零;校外又分为本市和外地两类,拨校外先拨0,假设是本地再接着拨8位数字固话第一位不是0或11位数字移动第一位为1;假设是外地,那么拨3位区码再拨8位固话第一位不是0,或拨0再拨11位数字移动第一位为1。请用数据定义的法,定义上述。答:=校|校外校=非0数字+3数字3校外=0+本地|外地本地=固话|手机固话=

13、非0数字+7数字7手机=1+10数字10外地=外地固话|外地手机外地固话=3数字3+固话外地手机=0+手机非0数字=1|2|3|4|5|6|7|8|9第三章1、为什么要进展需求分析?通常对软件系统有哪些需求?答:为了开发出真正满足用户需求的软件产品,准确定义未来系统的目标,确定为了满足用户的需要系统必须做什么,就必须要进展准确的需求分析。通常对软件系统的需求有:功能需求;性能需求;可靠性和可用性需求;出错处理需求;接口需求;约束;逆向需求;文档需求;数据需求等等。2、银行计算机储蓄系统的工作过程大致如下:储户填写的存款单或取款单由业务员键入系统,如果是存款那么系统记录存款人XX、住址、XX等存

14、款信息,并打印出存款存单给储户;如果是取款且存款时留有密码,那么系统首先核对储户密码,假设密码正确或存款时未留密码,那么系统计算利息并打印出利息清单给储户。答:用数据流图描述本系统的功能,并用ER图描绘系统中的数据对象。6、复印机的工作过程大致如下:未接到复印命令时处于闲置状态,一旦接到复印命令那么进入复印状态,完成一个复印命令规定的工作后又回到闲置状态,等待下一个复印命令;如果执行复印命令时发现没纸,那么进入缺纸状态,发出警告,等待装纸,装满纸后进入闲置状态,准备接收复印命令;如果复印时发生卡纸故障,那么进入卡纸状态,发出警告等待维修人员来排除故障,故障排除后回到闲置状态。请用状态转换图描绘

15、复印机的行为。答:从问题述可知,复印机的状态主要有“闲置、“复印、“缺纸和“卡纸。引起状态转换的事件主要是“复印命令、“完成复印命令、“发现缺纸、“装满纸、“发生卡纸故障和“排除了卡纸故障。 第四章不考,略。第五章5-4美国某大学共有200名教师,校与教师工会刚刚签订一项协议。按照协议,所有年工资超过26000(含26000)的教师工资将保持不变,年工资少于26000的教师将增加工资,所增加的工资数按下述法计算:给每个由此教师所赡养的人(包括教师本人)每年补助100,此外,教师有一年工龄每年再多补助50,但是,增加后的年工资总额不能多于26000。教师的工资档案储存在行政办公室的磁带上,档案中

16、有目前的年工资、赡养的人数、雇用日期等信息。需要写一个程序计算并印出每名教师的原有工资和调整后的新工资。要求:(1)画出此系统的数据流图;(2)写出需求说明;(3)设计上述的工资调整程序(要求用HIPO图描绘设计结果),设计时请分别采用下述两种算法,并比较这两种算法的优缺点:(a)搜索工资档案数据,找出年工资少于26000的人,计算新工资,校核是否超过26000,储存新工资,印出新旧工资对照表;(b)把工资档案数据按工资从最低到最高的次序排序,当工资数额超过26000时即停顿排序,计算新工资,校核是否超过限额,储存新工资,印出结果。答:第六章 6-3:画出以下伪码程序的程序流程图和盒图 及PA

17、D图。g While qfpn 6-4以下列图给出的程序流程图代表一个非构造化的程序,请问:1为什么说它是非构造化的?2设计一个等价的构造化程序。3在2题的设计中你使用附加的标志变量flag吗?假设没用,请再设计一个使用flag的程序;假设用了,再设计一个不用flag的程序。答:1通常所说的构造化程序,是按照狭义的构造程序的定义衡量,符合定义规定的程序。图示的程序的循环控制构造有两个出口,显然不符合狭义的构造程序的定义,因此是非构造化的程序。2使用附加的标志变量flag,至少有两种法可以把该程序改造为等价的构造化程序,以下列图描绘了等价的构造化程序的盒图。3不使用flag把该程序改造为等价的构

18、造化程序的法如图以下列图所示。6-5研究下面的伪代码程序:LOOP:SetIto(START+FINISH)/2IfTABLE(I)=ITEMgotoFOUNDIfTABLE(I)ITEMSetFINISHto(I-1)If(FINISH-START)1gotoLOOPIfTABLE(START)=ITEMgotoFOUNDIfTABLE(FINISH)=ITEMgotoFOUNDSetFLAGto0GotoDONEFOUND:SetFLAGto1DONE:Exit(1)画出程序流程图。(2)程序是构造化吗?说明理由。(3)假设程序是非构造化的,设计一个等价的构造化程序并且画出流程图。(4)此

19、程序的功能是什么?它完成预定功能有什么隐含的前提条件。答:1该程序流程图如下:2该程序不是构造化的,构造化的程序只有一个入口和一个出口,而该程序的流程途中有两个出口。3等价的构造化程序的流程图如下:4此程序有二分查找的功能,它完成预定功能的隐含前提条件是现有序列为从小到大顺序排好的有序序列。6-7某交易所规定给经纪人的手续费计算法如下:总手续费等于根本手续费加上与交易中的每股价格和股数有关的附加手续费。如果交易总金额少于1000元,那么根本手续费为交易金额的8.4%;如果交易总金额在1000元到10000元之间,那么根本手续费为交易金额的5%,再加34元;如果交易总金额超过10000元,那么根

20、本手续费为交易金额的4%加上134元。当每股售价低于14元时,附加手续费为根本手续费的5%,除非买进、卖出的股数不是100的倍数,在这种情况下附加手续费为根本手续费的9%。当每股售价在14元到25元之间时,附加手续费为根本手续费的2%,除非交易的股数不是100的倍数,在这种情况下附加手续费为根本手续费的6%。当每股售价超过25元时,如果交易的股数零散(即,不是100的倍数),那么附加手续费为根本手续费的4%,否那么附加手续费为根本手续费的1%。要求:(1) 用判定表表示手续费的计算法;(2)用判定树表示手续费的计算法。1答:判定表如以下列图所示:2判定树如以下列图所示:6-8画出以下伪码程序的

21、流图,计算它的环形复度。这个程序的逻辑有什么问题吗?C EXAMPLELOOP: DO WHILE Z 0A = B + 1IF A 10THEN X = AELSE Y = 2END IFIF Y 0THEN PRINT GELSE PRINT KEND IFSTOP答:1伪码的流程图如下所示:根据程序流程图可得该程序流图:环形复杂度V(G) 封闭的区域数=6 En2=18-14+2=6判断结点1=5162该算法问题在于控制最外层循环的变量Z不仅没有经过初始化,并且在该循环部没有任有可能该变Z的语句。因此,该段代码中的WHILE循环局部代码要么不会执行,要么可能出现死循环。 完毕第七章7-2

22、:解:程序流程图如图2.1所示此程序是非构造化的,它有一个GOTO语句,并且是从一个循环体转到循环体外的一个条件语句部。 修改后的伪码如下:程序中的错误: 语句“IFWORD=KEYWORD里的变量“WORD没有预先赋值。 程序中没有预先输入T的值 “N=0应该是“MATCH=07-4:答复以下问题。(1)什么是模块测试和集成测试?它们各有什么特点?(2)假设有一个由1000行FORTRAN语句构成的程序(经编译后大约有5000条机器指令),估计在对它进展测试期间将发现多少个错误?为什么?(3)设计以下伪码程序的语句覆盖和路径覆盖测试用例。STARTINPUT(A,B,C)IFA5THENX=

23、10ELSEX=1ENDIFIFB10THENY=20ELSEY=2ENDIFIFC15THENZ=30ELSEZ=3ENDIFPRINT(X,Y,Z)STOP解答:(1)模块测试:保证每个模块能完成一个清晰定义的子功能而且和其他模块的功能之间没有相互依赖的关系。其特点是:主要应用白盒测试的技术,对多个模块的测试可以并发的进展。集成测试:又称为组装测试,就是将软件产品中各个模块组装起来,检查其接口是否存在问题,以及组装后的整体功能、性能表现。特点是:可能发生接口问题。(2)经历说明,在类似的程序中,单位长度里的错误数ET/IT近似为常数。美国的一些统计数字说明,通常:0.005=ET/IT=0

24、.02,即在测试之前,每1000条指令约有520个错误。所以,在对1000行FORTRAN语句构成的程序进展测试期间将发现的错误的个数大约有25100个。(3)该伪码程序对应的程序流程图如下:从上到下每个判定依次命名为a、b、c:7-8:对一个包含10000条机器指令的程序进展一个月集成测试后,总共改正了15个错误,此时MTTF=10h;经过两个月测试后,总共改正了25个错误(第二个月改正了10个错误),MTTF=15h。要求:(1)根据上述数据确定MTTF与测试时间之间的函数关系,画出MTTF与测试时间的关系曲线。在画这条曲线时做了什么假设?(2)为做到MTTF=100h,必须进展多长时间的

25、集成测试?(3)当集成测试完毕时总共改正了多少个错误,还有多少个错误潜伏在程序中?解答:(1)因为平均无故障时间MTTF与测试时间之间存在线性关系,即MTTF=a+b,由于:10=a+b,15=a+2b,得到:a=5,b=5故:平均无故障时间MTTF与测试时间之间存在线性关系为:MTTF=5+5(2)为做到MTTF=100h,有程:100=5+5,故=19即必须进展19个月的集成测试。(3)由于经历:平均无故障时间与单位长度程序中剩余的错误数成反比,故有:MTTF=10000/(K*(ET-EC()由于:10=10000/(K*(ET-15),15=10000/(K*(ET-25)得到:ET=

26、45,K=33.33当集成测试完毕时,MTTF=100h,有:100=10000/(33.33*(45-EC(19)故:EC(19)=42,即当集成测试完毕时总共改正了42个错误,还有45-42=3个错误潜伏在程序中。7-9:如对一个长度为100000条指令的程序进展集成测试期间记录下下面的数据:a7月1日:集成测试开场,没有发现错误。b8月2日:总共改正100个错误,此时MTTF=0.4hc9月1日:总共改正300个错误,此时MTTF=2h根据上列数据完成以下各题。1估计程序中的错误总数。2为使MTTF到达10h,必须测试和调试这个程序多长时间?3画出MTTF和测试时间之间的函数关系曲线。解

27、答:1据估算平均无故障时间MTTF的公式有:1/K(Et/100000-100/100000)=0.41/K(Et/100000-300/100000)=2得:K1000,Et=350即程序中的错误总数达350。2当MTTF10h时,有1/K(350/100000-Ec/100000)=10得:Ec=340.按七八月分测试改错进度估算,还需进展2个月的集成测试。3MTTF和测试时间之间的函数关系曲线如下:7-10:在测试一个长度为24000条指令的程序时,第一个月由甲、乙两名测试员各自独立测试这个程序。经一个月测试后,甲发现并改正20个错误,使MTTF到达10h。与此同时,乙发现24个错误,其

28、中6个甲也发现了。以后由甲一个人继续测试这个程序。问:(1)刚开场测试时程序中总共有多少个潜藏的错误?(2)为使MTTF到达60h,必须再改正多少个错误?还需用多长测试时间?(3)画出MTTF与集成测试时间之间的函数关系曲线。解答:(1)此题中采用的是分别测试法,测试前程序中的错误总数:B0=B1*B2/bc=20*24/6=80(2)由于经历:平均无故障时间与单位长度程序中剩余的错误数成反比,故有:MTTF=24000/(K*(ET-EC()由于:10=24000/(K*(80-20)得到:K=40为使MTTF到达60h,有:60=24000/(40*(80-EC()故:EC()=70,即总

29、共需要改正70个错误,由于测试员甲和乙分别测试时,测试员甲已经更正了20个错误,以后由甲一个人继续测试这个程序,因此,还需要更正70-20=50个错误。补充:【复旦大学2001年博士研究生入学考试试题】某模块的程序流程图如下。试分别根据判定覆盖、条件覆盖、判定/条件覆盖、条件组合覆盖和路径覆盖等覆盖标准设计最少的测试用例。第八章8-1:软件的可维护性与哪些因素有关?在软件开发过程中应该采取哪些措施来提高软件产品的可维护性?1、1可理解性2可测试性3可修改性4可移植性5可重用性2、8-2:假设自己的任务是对一个已有的软件做重大修改,而且只允从下述文档中选取两份:(a)程序的规格说明;(b)程序的详细设计结果(自然语言描述加上某种设计工具表示);(c)源程序清单(其中有适当数量的注解)。应选取哪两份文档?为什么这样选取?打算怎样完成交给自己的任务?解答:1选AC2原因:首先需要对软件做修改,就必须得有源代码,C是必选。其次,软件规格说明书作为产品需求的最终成果,具有综合性,包括了所有的需求;其中主要的有:任务概述,数据描述,功能需求,性能需求,运行需求,其他需求;这些都是修改软件必须参考的容,应选择A。综上,根据规格说明再结合源程序以及源程序里的注释,足够对软件进展修改。3结合需求,规格说明书以及源代码,按照软件工程的法一步步去理解,修改,测试,调试代码。. .word.zl.

展开阅读全文
部分上传会员的收益排行 01、路***(¥15400+),02、曲****(¥15300+),
03、wei****016(¥13200+),04、大***流(¥12600+),
05、Fis****915(¥4200+),06、h****i(¥4100+),
07、Q**(¥3400+),08、自******点(¥2400+),
09、h*****x(¥1400+),10、c****e(¥1100+),
11、be*****ha(¥800+),12、13********8(¥800+)。
相似文档                                   自信AI助手自信AI助手
搜索标签

当前位置:首页 > 教育专区 > 其他

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2024 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服