好文档就是一把金锄头!
欢迎来到金锄头文库![会员中心]
电子文档交易市场
安卓APP | ios版本
电子文档交易市场
安卓APP | ios版本

软件工程-原理方法与应用第三版重点.docx

47页
  • 卖家[上传人]:cl****1
  • 文档编号:484478449
  • 上传时间:2023-03-04
  • 文档格式:DOCX
  • 文档大小:267.40KB
  • / 47 举报 版权申诉 马上下载
  • 文本预览
  • 下载提示
  • 常见问题
    • 软件工程-原理、方法与应用【第 三版】重点第一章绪论1. 软件:是能够完成预定功能和性能的可执行的计算机诚信度包括使程序正常执行所需的数据,以及有关描述程 序操作和使用的文档即:软件 =程序+文档2. 软件的特征:软件的开发不同于硬件设计、不同于硬件制造、不同于硬件维修3. 软件工程方法学:把在软件生命周期全过程中使用的一整套技术方法的集合三要素:方法、工具、过程4. 软件工程学的范畴:软件开发技术(软件开发方法学、软件工具、软件工程环境)、软件工程管理(软件管理学、软件经济学、度量学)5. 软件工程:是指导计算机软件开发和维护的工程学科它采用工程的概念、原理、技术和方法来开发与维护软件, 目的是为了实现按照预期的进度和经费完成软件生产计 戈同时提高软件的生产率和可靠性6. 软件的发展:大体经历了 程序、软件、软件产品3个阶段7. 工具和方法是软件开发技术的2大支柱8.3种编程泛型:过程式编程泛型、面向对象编程泛型、基 于构件技术的编程泛型9. 面向对象程序设计中,数据和操作被封装在一个对象中,对象之间则是通过消息相互联系10. 构件:标准化/规格化的对象类11. 3种编程泛型的差异:粒度由小到大依次是:过程式编 程范式、面向对象编程范式、基于构件的编程泛型。

      12. 软件工程的分化:1、传统软件工程2、面向对象软件工 程3、基于构件的软件工程13. 消除软件危机的途径:①正确认识计算机软件;②充分 认识到软件开发是一种组织良好、管理严密、各类人员 协同工作的工程项目;推广使用在实践中总结出来的开 发软件的成功的技术和方法;③开发和使用更好的软件 工具第二章软件生存周期与软件过程1. 软件生存周期:计划、开发、运行 3个时期需求分析-》软件分析-》软件设计-》编码测试-》软件测试-》 运行维护2. 需求分析(用户视角):功能需求、性能需求、环境约束、外部接口描述3. 软件分析(开发人员视角):建立与需求模型一致的,与实现无关的软件分析模型4. 软件设计:总体设计/概要设计、详细设计(确定软件的数据结构和操作)5. 软件测试:单元测试、集成测试、系统测试6. 软件开发方法可区分:形式化方法、非形式化方法开发模型特点场合瀑布模型(历史悠久、广为人知,它的优势在于它是规范的、 文档驱动的方法;这种模型的问题是,最终开发的软件产品可能并不是客户 真正需要的)线性模型,每个阶段必须完成 固定文档需求明确的中小型软件开发快速原型模型(正是为了克服瀑布模型的缺点提出来的,他通过快速构建起一个可以在计算机上运行的原型系统, 让用户使用原型并收集用户反馈意见的方法,获取用户的真实需求 )用户介入早,通过迭代完善用户需求,应用快速开发工具需求模糊的小型软件开发增量模型(具有可在软件开发的早期阶使投资获得明显回报和 交易维护的优点,但是,要求软件具有开放的结构是使用这种模型固有的困 难。

      每次迭代完成一个增量,可用 于OO开发容易分块的大型软件开发螺旋模型(适用于内开发的大型软件项目,但是只有在开发人员具有风险分 析和排除风险的经验及专门知识时,使用这种模型才会成功 )典型迭代模型,重视风险分析,可用于OO开发具有不确定性的大型软件开发构件集成模型(面向对象基于构件库,融合螺旋模型的特 征,支持软件开发,迭代方法,软件复用思想 )软件开发与构件开发平行进 行,主要用于OO开发领域工程, 件开发,主行业的中型软它要用于00开发转换模型(是将形式化软件开发和程序自动生成技术相结合的 一种软件开发模型形式化的需求规格说明书,自 动的程序变换系统理想化的模型,尚无成熟工具支持净室模型(是一种形式化的增量开发模型,其基本思想是力求 在分析和设计阶段就消除错误,确保正确,然后在无缺陷或洁净的状态下实 现软件的制作形式化的增量开发模型,在洁净状态下实现软件的制作开发团队熟悉形式化方法,中小型软件开发7. 形式化开发模型:转换模型、净室模型8. 软件可行性研究:经济可行性、技术可行性、运行可行性、法律可行性9. 可行性研究的步骤:对当前系统进行调查研究、导出新系统的解决方案、提出推荐方案、编写可行性论证报告。

      10. 可行性论证报告的内容:系统概述、可行性分析、结论 意见11. 软件风险分析包括:风险识别(项目风险、技术风险、 商业风险)、风险预测、风险的驾驭和监控12. 软件计划的7种类型:项目实施计划、质量保证计划、 软件测试计划、文档编制计划、用户培训计划、综合支 持计划、软件分发计划第三章结构化分析与设计1. 瀑布模型的生命周期:需求定义与分析-》总体设计-》详细设计-》编码-》测试-》维护2. 系统的开发流程(SA和SD流程):结构化分析(工具:DFD PSPEC ------》分析模型(分层DFD 图)+SRS结构化设计(工具:SC图(映射)------》初始设计模型(初 始SC图)初始设计模型(初始SC图)(优化) 》最终设计模型(最终SC图)3. SA需求分析的两项基本任务:建立系统分析模型、编写SRS4. 分析模型组成:功能模型、数据模型、行为模型 3种,5. 抽象 和 分解 是结构化分析的主要指导思想,细化的实质是分解分解 和 细化 是软件设计的策略6. SD阶段把分析模型中的DFD图转换为 最终SC图7. 传统软件的开发技术:结构化设计、模块设计8. 软件设计:总体设计/概要设计(初始SC图、最终SC图)、详细设计(用逐步细化的方法,完成模块的说明)。

      9. 需求分析的步骤:需求获取、需求提炼、需求描述、需求验证10. DFD图不能表示程序的控制结构(如选择、循环结构)11. 加工规格说明通常用结构化语言、判定表、判定树作为描述工具12. 软件中的数据分为3类:数据项(数据元素)、数据流(多个相关数据项)、数据文件和数据库13. 数据字典的组成:数据项、数据流、数据存储(文件或数 据库)、加工(处理逻辑)、外部项(人、物或其它软件系 统)14. SD模型是由SA模型映射而来的SA模型的数据字典可转换为待开发系统的数据 设计数据流图可转换为体系结构设计(SC图)与接口设计加工规格说明可转换为模块内部的详细过程设计15. SD模型的组成:从上到下依次是:过程设计、接口设计、体系结构设计、数据设计16. 结构化分析的基本步骤:自顶向下对系统进行功能分解,画出 DFD图;由后向前定义系 统的数据和加工;编制 DD和 PEPES写出SRS17. 把不需要分解的加工成为基本加工把逐步分解成为“自 顶向下,逐步细化”18. DFD的优点:便于实现,便于使用19. 传统的软件设计可细分为:面向数据流设计(SD方法)、 面向数据结构设计(Jackson方法)。

      20. 用数据流图表示逻辑模型,在设计阶段,按照数据流图的不同类型(变换型、事务型)转换为相应的软件结构21. 结构化设计通常从DFD图到SC图的映射开始22.面向数据流的设计方法:从图到SC图的映射的4个步变授和DFD爭帖"DFD变换甘析事务分析初始scDFD骤:1、 复审DFD图,必要时可再次进行修改或细化;2、 鉴别DFD图的结构特征:事务?变换?;3、 按照规则,把DFD图为初始的SC图;4、改进初始的SC图23. 变换型结构:由输入、变换中心和输出三部分组成 事务型结构:具有在多种事务中选择执行某类事物的能力24. 变换映射的步骤:划分DFD图的边界、建立初始SC图的 框架、分解SC图的各个分支事务映射的步骤:在 DFD图上确定边界、画出SC图框架、分 解和细化接受分支和发送分支25. 优化结构设计的指导规则:对模块分割、合并和变动调 用关系的指导规则、保持高扇入/低扇出的原则、作用域 /控制域规则26. 模块设计(详细设计)的主要任务是编写软件的模块设 计说明书目的是确定模块采用的算法和块内数据结构27. 模块设计的原则:清晰第一的设计风格、结构化的控制 结构、逐步细化的实现方法。

      28. 结构化程序设计原理和逐步细化的实现方法是完成模块 设计的基础第四章面向对象和UML1. 面向对象的基本特征:抽象、圭寸装、集成、多态2. 面向对象开发的优点:提高软件系统的可复用性、可扩展性、可维护性、面向对象符合人类习惯的思维方式3. 元素之间的联系有:关联、泛化、依赖、实现、聚集、组合4. UML的4个抽象层次:用户模型、模型、元模型、元元模型5. UML的2类图:静态图(用例图、类图、对象图、构件图、部署图); 动态图(状态图、时序图、协作图、活动图)UML的5种视图:用例视图、逻辑视图、进程视图、构件视图、 部署视图6. UML的特点:统一标准、面向对象、表达能力强,可视化7. UML模型作为测试阶段的依据:单元测试使用类图和类规格说明;集成测试使用构件图和协作 图;系统测试使用用例图来验证系统行为8. UML中用例图由系统边界、用例、参与者、关联组成用例之间存在的关系:扩展关系、包含关系包与包之间的关系有:依赖、泛化9. 根据类/对象之间的具体情况,可分为普通关联,递归关联、多重关联、有序关联、限制关联、或关联、关联类10. 消息(类里面的方法加参数):简单消息、同步消息、异 步消息。

      状态图有:初态、终态、中间态11. 时序图中的消息可以是信号或操作调用12. 时序图着重体现交互的时间顺序;协作图着重体现交互 对象间的静态链接13. 时序图和协作图适合描述单个用例中几个对象的行为;活动图适合表现跨越多用例或多线程的复杂行为14. 构件图可以用来表现、编译、链接、执行时构件间的依 赖关系15. UML用图表示语法,用元模型表示语义,米用模型来描 述系统的结构(静态特征)以及行为(动态特征)第五章需求工程和需求分析1. 软件需求的3个层次:业务需求、用户需求、功能需求软件项目中40%〜60的问题源自软件需求阶段2. 软件需求的6个特性:功能性、可用性、可靠性、性能、可支持性、设计约束3. 需求分析的步骤:需求获取、需求建模、需求描述(编写SRS、需求验证4. 需求分析的主要任务:建立需求模型需求分析是迭代过程常见模型有:用例图、数据流图、实体联系图、控制流图、状 态转换图5. 需求获取的方法:1、建立联合分析小组2、用户访谈6. 获得用例的方法通过问问题:1、系统用户是谁?系统维护时谁?从哪获得信息?给谁?7. 需求建模方法:结构化分析建模方法、面向对象分析建模8. 结构化需求模型由3部分组成:功能模型(数据流图、加工规格说明书)、数据模型(数据字典、ER图)、行为模 型(状态转换图、控制流图、控制规格说明书)。

      9. 面向对象需求模型:用例模型(用例图、用例规约) 、补充规约、术语表10. 面向对象需求建模的步骤:画用例图、写用例规约、描 述补充规约、编写术语表、调整优化11. 用例规约文档的内容:简要说明、事件流、特殊需求、 前置条件和后置条件12. 用例规约的检查:功能需求的完备性、模型是否易于理 解、是否存在不一致性、避免二义性13. 软件需求规格说明书SRS的内容:引言、信息描述、功 能描述、行为描述、质量保证。

      点击阅读更多内容
      关于金锄头网 - 版权申诉 - 免责声明 - 诚邀英才 - 联系我们
      手机版 | 川公网安备 51140202000112号 | 经营许可证(蜀ICP备13022795号)
      ©2008-2016 by Sichuan Goldhoe Inc. All Rights Reserved.