### 软件工程基础知识详解
#### 一、软件需求分析阶段的工作
- **需求获取**:通过与客户的沟通和调研,明确客户的需求。
- **需求分析**:对收集到的需求进行深入研究,理解需求背后的原因及目的。
- **编写需求规格说明书**:将分析后的需求文档化,形成正式的需求规格说明书。
- **需求评审**:组织专家或利益相关方对需求规格说明书进行审查,确保需求的准确性和完整性。
#### 二、原型法中的用户/设计者概念
- 在原型法中,**用户**被视为“用户/设计者”,用户参与到软件开发的过程中,通过与开发团队的互动,不断调整和完善原型,直至满足最终需求。
#### 三、软件工程的三个基本要素
- **工具**:支持软件开发活动的硬件和软件工具。
- **过程**:软件开发过程中遵循的一系列步骤和规则。
- **方法**:指导软件开发的具体技术和策略。
#### 四、软件测试类型
- **确认测试**:验证软件产品的功能和性能是否符合需求定义的过程。
- **集成测试**:测试软件组件之间的交互。
- **验证测试**:确保软件组件按照预期工作。
- **验收测试**:最终用户或客户确认软件是否满足其需求的测试。
#### 五、数据存储和数据流的概念
- 数据存储和数据流本质上都是**数据**的不同状态形式,数据流指的是数据在系统中的流动,而数据存储则是指数据的静态存储形式。
#### 六、数据流图及其组成部分
- **数据流图**用于描述软件的逻辑模型,它包括以下几个核心组成部分:
- **加工**:表示对数据进行处理或转换的节点。
- **数据存储**:表示数据的静态存储位置。
- **源和汇**:分别表示数据的来源和去向。
- 不属于数据流图的合法图符:**控制流**(数据流图关注的是数据的流动而非控制流)。
#### 七、结构化分析方法
- 结构化分析方法是一种面向**数据流**的需求分析方法,通过自顶向下逐步细化的过程,帮助理解和描述系统的功能需求。
#### 八、软件功能分解
- 通过**功能分解**可以进一步细化数据流图,将其分解为更小的功能模块,以便更好地理解和实现。
#### 九、软件工程原则
- **抽象**:从复杂性中提取关键特征。
- **模块化**:将系统划分为独立且易于管理的模块。
- **自底向上**:从底层模块开始构建系统,不是软件工程的基本原则之一。
- **信息隐蔽**:每个模块仅暴露必要的接口,隐藏内部实现细节。
#### 十、模块概念
- 模块是数据说明、可执行语句等程序对象的集合,具有单独的命名,并可通过名字访问。
#### 十一、局部化的概念
- 局部化是指让关系密切的软件元素在物理上彼此靠近,有助于提高代码的可读性和可维护性。
#### 十二、面向数据流的设计方法
- 面向数据流的设计方法将**信息流**映射成软件结构,这种设计方法强调了数据在系统中的流动路径。
#### 十三、程序流程图中的箭头含义
- 程序流程图(PDF)中的箭头代表**控制流**,即程序执行的顺序和路径。
#### 十四、软件结构设计原理
- 在进行软件结构设计时,最核心的原理是**模块独立**,即将系统划分为尽可能独立的模块,以降低模块间的耦合度。
#### 十五、软件功能分解阶段
- 在结构化方法中,软件功能分解属于**总体设计**阶段的一部分,这个阶段主要关注系统的大致结构和模块划分。
#### 十六、软件测试的目的
- 测试的主要目的是**发现程序中的错误**,并通过执行程序来验证其行为是否符合预期。
#### 十七、需求分析常用工具
- 常用的需求分析工具包括**数据流图(DFD)**,它能够清晰地描述系统中数据的流动情况。
#### 十八、软件调试的目标
- 软件调试的目标是**改正错误**,即修复程序中存在的缺陷。
#### 十九、软件开发方法
- **自顶向下**是一种常见的软件工程方法,它从高层次的系统设计开始,逐步细化到具体的模块和功能。
#### 二十、软件工具箱机制
- **环境集成**机制使得不同的软件工具能够通过统一的数据接口规范共享环境信息库中的信息。
#### 二十一、用户参与
- 在软件生命周期的不同阶段,用户的参与程度各不相同,但在**软件定义期**,用户参与尤为重要,因为他们需要与开发者一起确定软件的基本需求和功能。
#### 二十二、软件定义期问题定义阶段的参与者
- **系统分析员**、**软件开发人员**、**用户**和**使用部门负责人**共同参与此阶段,确保需求定义的准确性。
#### 二十三、软件详细设计方法
- **结构化程序设计**是一种常用的详细设计方法,强调清晰的模块划分和良好的代码结构。
#### 二十四、接口控制的重要性
- 接口控制涉及到模块间的相互作用和资源的共享,对于确保系统的稳定性和可靠性至关重要。
#### 二十五、模块的概念
- **模块**是程序中逻辑上可以分离的部分,它是离散的程序单位,具有独立的功能。
#### 二十六、原型化方法的应用条件
- 成熟的原型化人员和快速的成型工具是实施原型化方法所必需的条件之一,这有助于快速迭代和反馈,从而更好地满足客户需求。
#### 二十七、判定树和判定表的作用
- **判定树**和**判定表**主要用于描述结构化分析中的数据加工环节,帮助清晰地表达复杂的决策逻辑。
#### 二十八、概要设计的结果
- 概要设计的结果通常是一份**模块说明书**,其中详细描述了每个模块的功能、接口和其他相关信息。