《软件工程基础考试重点(共4页).doc》由会员分享,可在线阅读,更多相关《软件工程基础考试重点(共4页).doc(4页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精选优质文档-倾情为你奉上1 软件危机指在计算机软件的开发和维护过程中所遇到的一系列严重问题2 软件危机的原因有:1客观:软件规模大、复杂性高2主观:忽视需求分析3 软件危机的主要表现:(1) 对软件开发成本和进度的估计常常不准确(2)用户对已完成系统不满意的现象经常发生(3)软件产品质量往往靠不住(4)软件常常是不可维护的(5)软件通常没有适当的文档资料(6)软件的成本不断提高(7)软件开发生产率的提高赶不上硬件的发展和人们需求的增长4 软件工程:采用工程的概念、原理、技术和方法来开发与维护软件,把经过时间考验、证明正确的管理技术和当前能够得到的做好的技术方法结合起来。经济地开发出高质量的软
2、件并有效地维护它5 软件工程原理:(1)用分阶段的生命周期计划严格管理(2)坚持进行阶段评审(3)实行严格的产品控制(4)采纳现代程序设计技术(5)结果应能清楚地审查(6)开发小组的人员应少儿精(7)承认不断改进软件工程实践的必要性6 生存期模型:瀑布模型、循环模型、演化模型、螺旋模型7 软件生存周期:从某个待开发软件的目的被提出并着手实现,直到最后停止使用的这个过程。8 生存周期阶段: 定义阶段(系统分析、制定软件项目计划、需求分析);开发阶段(软件设计、编码、软件测试);维护阶段(改正性维护,适应性维护,完善性维护,预防性维护)9 软件开发的模式:1 瀑布模式 (初始目标、需求分析、软件设
3、计、编码、测试、运行维护)2原型法模式 3演化模式4螺旋模式10 软件定义过程分阶段:问题的定义、可行性研究、需求分析11 可行性研究目的:以最小的代价在尽可能短的时间内确定问题是否能够解决。可行性研究包括:经济、技术、法律和方案选择性12 可行性研究包括:经济可行性、技术可行性、法律可行性、方案选择性、13需求分析:软件需求是指用户对于目标系统在功能.、行为、性能、设计约束等方面的期望。通过对应问题及其环境的理解和分析,为问题涉及的信息、功能及系统行为进行建模,将用户需求精确化、完整化和清晰化,最终形成需求规格说明。14 需求分析任务:确定系统的综合要求、分析系统的数据要求、导出系统的逻辑模
4、型、修正系统的开发计划、开发原型系统。15 初步需求获取技术:访谈与会议、观察用户工作流程、用户与开发人员组成联合小组16 结构化分析方法:简称SA方法,它是一种面向数据流的需求分析方法,适用于分析大型数据处理系统,是一种简单、实用的方法。17 SA方法分析结果组成:一套分层的数据流图、一本数据字典、一组加工逻辑说明和补充材料18 数据流图(DFD):描绘系统的逻辑模型,图中没有任何具体的物理元素,只是描绘信息在系统中流动和处理的情况。是一种用逻辑系统的图形表示, 便于用户理解、分析系统数据流程的分析工具19 数据流图基本成分:外部实体-方框、加工-圆、数据存储-平行线、数据流-箭头20 数据
5、字典:就是为数据流图中的每个数据流、文件、加工、以及组成数据流或文件的数据项做出说明 21 数据字典条目内容:(1)数据流图中标识数据流、数据源或外部实体的名称与别名(2)数据类型(3)所有以它作为输入流或输出流的转换的列表(4)使用该数据条目的简要说明(5)数据条目的解释性说明(6)其他补充说明 在数据流图中,每个加工框中只简单地写上了一个加工名,这显然不能表达加工的全部内容。随着自顶向下逐步细化,功能越来越具体,加工逻辑也越来越精细。到最底一层,加工逻辑详细到可以实现的程度,因此称为“原子加工”或“基本加工”。如果能够写出每一个基本加工的全部详细逻辑功能,再自底向上综合,就能完成全部逻辑加
6、工。22 加工逻辑的描述方法:结构化语言、判定表、判定树23 概要设计任务:设计实现软件的最佳方案、设计软件体系结构24 模块化:按照一定原则把程序划分成若干个模块、使每个模块完成一个子功能 模块多,开发单个模块工作量减少,与模块接口有关工作增加。必须减少接口复杂提高独立性。模块特性:输入输出、功能、内部数据、程序代码25抽象:对事物共同的本质特性进行抽取和概括,忽略次要因素逐步求精:自顶向下的设计策略26 信息隐蔽:在设计和确定模块时,使得一个模块内包含的信息(过程或数据)对于不需要这些信息的模块来说是不能访问的局部化:在设计和确定模块时把一些关系密切的软件元素物理地放的彼此靠近27 模块独
7、立性:每个模块只完成系统要求的独立子功能,并且与模块的联系最少且接口简单 模块独立可用两个定向标准度量:内聚性(快内联系,一个模块内部各个元素彼此结合的紧密程度的度量,大) 耦合性(块间联系,各模块间相互联系的紧密程度,小)28 内聚度低到高:偶然内聚、逻辑、时间、过程、通信、信息、功能内聚 耦合性从高到低:内容耦合、公共、外部、控制、标记、数据、非直接耦合29 软件结构优化的原则:改善独立性;模块规模应该适中;深度、宽度、扇入和扇出要适当;作用域应在控制域内;设计单入口单出口的模块;力争降低模块接口的复杂程度;功能应该可以预测。30 详细设计的原则:(1) 采用自顶向下逐步求精的设计方法。(
8、2) 使用言语中的顺序、选择、重复等有限的基本结构表示程序逻辑。(3) 选用的控制结构只允许一个入口和一个出口。(4) 复杂结构应该用基本控制结构进行组合嵌套来实现。(5) 严格控制GO TO语句。31 详细设计方法:程序流程图、N-S图、PAD图、PDL32 程序里程图中主要符号元素的含义:方框表示加工任务:菱形表示逻辑条件;箭头表示控制流.33 程序流程图主要缺点:(1)程序流程图本质上不是逐步求精的好工具,它诱使程序员过早地考虑程序的控制流程,而不去考虑程序的全局结构。(2)程序流程图中用箭头代表控制流,因此,程序员不受任何约束,可以完全不顾结构程序设计的精神,随意转移控制。 程序流程图
9、不宜表示数据结构 N-S图有下述特点:(1)功能域(即一个特定控制结构的作用域)明确(2)不可能任意转移控制(3)很容易确定局部和全程数据的作用域(4)很容易表现嵌套关系,也可以表示模块的层次结构。PAD图的主要优点:(1)使用表示结构化控制结构的PAD符号设计出来的程序必然是结构化程序。(2)PAD图描绘的程序结构十分清晰。(3)容易将PAD图转换成高级语言源程序,这种转换可用软件工具自动完成,从而可省去人工编码的工作,有利于提高软件的可靠性和(英文或中文)软件的生产率。(4)既可用于表示程序逻辑,也可用于描绘数据结构。(5)PAD图的符号支持自顶向下,逐步求精方法的使用。PDL具有以下特点
10、:(1)提供全部结构化控制结构、数据说明和模块特征。能对PDL正文进行结构分割,使之变得易于理解。(2)关键字语法固定。(3)数据处理使用结构化语(4)数据说明应该满足自定义数据类型的要求(5)模块定义和接口描述应该类某种语言风格。34软件测试的原则:(1)应当经早的和不断的进行软件测试,(2)测试用例应当由测试输入数据和与之对立的与其输出结果组成(3)开发人员和测试队伍要分别建立,为保证测试质量应分别建立开发和测试队伍(4)设计测试用例时应包括合理的输入条件合不合理的输入条件(5)充分注意测试中的群集现象(6)严格执行测试计划排除测试的随意行(7)应当对每一个测试的结果做全面检测(8)在对程
11、序进行修改后要进行回归测试(9)妥善保存测试计划、测试用例、出错统计和最终分析报告,为维护提供方便。35白盒测试又称玻璃盒测试,对软件的过程性描述做细致的检查,把测试对象看着一个打开的盒子,允许利用程序内部的逻辑结构及有关信息,设计或选择测试用例,对程序所有逻辑路径进行测试。通过在不同点检查程序的状态,取得实际的状态,是否与预期的状态一致,故又称结构测试或逻辑驱动。可以(1)保证一个模块中的所有独立路径至少被使用一次;(2)对所有逻辑值均需测试真和假;(3)在上下边界及可操作范围内运行所有循环;(4)检查内部数据结构以确保其有效性。是36黑盒测试也称作行为测试在完全不考虑程序的内部结构和处理过
12、程的前提下,在程序接口进行的测试,它只检查程序功能是否能按照规格说明书的规定正常使用,程序是否能适当地接受输入数据产生正确的输出信息,并且保持外部信息的完整性。因此,又称为功能测试或数据驱动合理地应用黑盒测试可以导出满足以下标准的测试案例集:能够减少达到合理测试所需的测试数;能够判断某些类型的错误存在与否,且与特定测试无关。白盒测试技术基本路径测试,控制结构测试黑盒测试技术等价划分,边界值分析。软件测试策略:单元、集成、确认、系统37 单元测试 集中检验软件设计的最小单元模块。单元测试可以使用白盒测试法,而且对多个模块的测试可以并行地进行。 常见的错误有1.不正确的算数优先级2.混合模式操作3
13、.精度不够准确4.错误的初始化。在单元测试的基础上,我们通常需要对由经过单元测试的模块组装起来形成的一个子系统进行的测试,这样的测试被称为子系统测试。子系统测试时重点测试模块的接口。而对由经过测试的子系统测试组装成的系统进行的测试则称为系统测试。38集成测试又叫组装测试。通过测试发现和接口有关的问题来构造程序结构的系统化技术,目标是将单元测试通过的模块构造一个符合设计描述的程序结构。集成测试方法可以分为两类一是非渐增式测试,一是渐增式测试。集成测试策略:自顶向下集成,自底向上集成,回归测试。39 确认测试a测试 由用户在开发者的场所进行,用户在开发者指导下对软件进行测试,开发者负责记录错误和使用中出现的问题,总的来说,a测试是在受控环境中进行。B测试 由用户在一个或多个用户场所进行,开发者通常不在场,因此,B测试是在开发者不能控制的环境下进行,用户记下所有的问题(实际出现的和可能出现的),并定期记录反馈回开发者,在接到B测试的用户报告后,开发者对系统进行修改。软件维护:指软件系统交付使用以后,为了改正软件运行错误,或者满足新的需求而加入新功能的修改软件过程。软件维护:改正性维护、适应性维护、完善性维护、预防性维护文档分为用户文档和系统文档 专心-专注-专业
限制150内