第1章 软件工程学概述 1
1.1 软件危机 1
1.1.1 软件危机的介绍 1
1.1.2 产生软件危机的原因 3
1.1.3 消除软件危机的途径 4
1.2 软件工程 5
1.2.1 软件工程的介绍 5
1.2.2 软件工程的基本原理 7
1.2.3 软件工程方法学 9
1.3 软件生命周期 11
1.4 软件过程 14
1.4.1 瀑布模型 15
1.4.2 快速原型模型 16
1.4.3 增量模型 17
1.4.4 螺旋模型 19
1.5 小结 21
习题1 22
第2章 可行性研究 25
2.1 可行性研究的任务 25
2.2 可行性研究过程 26
2.3 系统流程图 28
2.3.1 符号 28
2.3.2 例子 28
2.3.3 分层 30
2.4 数据流图 30
2.4.1 符号 30
2.4.2 例子 32
2.4.3 命名 34
2.4.4 用途 35
2.5 数据字典 37
2.5.1 数据字典的内容 37
2.5.2 定义数据的方法 37
2.5.3 数据字典的用途 38
2.5.4 数据字典的实现 39
2.6 成本/效益分析 39
2.6.1 成本估计 40
2.6.2 成本/效益分析的方法 41
2.7 小结 43
习题2 43
第3章 需求分析 45
3.1 需求分析的任务 46
3.1.1 确定对系统的综合要求 46
3.1.2 分析系统的数据要求 47
3.1.3 导出系统的逻辑模型 48
3.1.4 修正系统开发计划 48
3.2 与用户沟通获取需求的方法 48
3.2.1 访谈 48
3.2.2 面向数据流自顶向下求精 49
3.2.3 简易的应用规格说明技术 49
3.2.4 快速建立软件原型 51
3.3 分析建模与规格说明 52
3.3.1 分析建模 52
3.3.2 软件需求规格说明 52
3.4 实体-联系图 52
3.4.1 数据对象 53
3.4.2 属性 53
3.4.3 联系 53
3.4.4 实体-联系图的符号 54
3.5 数据规范化 54
3.6 状态转换图 55
3.6.1状态 55
3.6.2 事件 55
3.6.3 符号 56
3.6.4 例子 56
3.7 其他图形工具 57
3.7.1 层次方框图 58
3.7.2 Warnier图 58
3.7.3 IPO图 59
3.8 验证软件需求 60
3.8.1 从哪些方面验证软件需求的正确性 60
3.8.2 验证软件需求的方法 60
3.8.3 用于需求分析的软件工具 61
3.9 小结 62
习题3 63
第4章 形式化说明技术 65
4.1 概述 65
4.1.1 非形式化方法的缺点 65
4.1.2 形式化方法的优点 66
4.1.3 应用形式化方法的准则 66
4.2 有穷状态机 67
4.2.1 概念 67
4.2.2 例子 69
4.2.3 评价 72
4.3 Petri网 72
4.3.1 概念 72
4.3.2 例子 74
4.4 Z语言 75
4.4.1简介 75
4.4.2 评价 78
4.5 小结 78
习题 4 79
第5章 总体设计 81
5.1 设计过程 81
5.2 设计原理 84
5.2.1 模块化 84
5.2.2 抽象 85
5.2.3 逐步求精 85
5.2.4 信息隐藏和局部化 86
5.2.5 模块独立 87
5.3 启发规则 89
5.4 描绘软件结构的图形工具 92
5.4.1层次图和HIPO图 92
5.4.2 结构图 93
5.5 面向数据流的设计方法 94
5.5.1 概念 94
5.5.2 变换分析 95
5.5.3 事务分析 101
5.5.4 设计优化 102
5.6 小结 103
习题5 104
第6章详细设计 107
6.1 结构程序设计 107
6.2 人机界面设计 109
6.2.1 设计问题 109
6.2.2 设计过程 111
6.2.3 人机界面设计指南 112
6.3 过程设计的工具 114
6.3.1 程序流程图 114
6.3.2 盒图(N-S图) 114
6.3.3 PAD图 116
6.3.4 判定表 117
6.3.5 判定树 118
6.3.6 过程设计语言 118
6.4 面向数据结构的设计方法 119
6.4.1 Jackson图 120
6.4.2 改进的Jackson图 121
6.4.3 Jackson方法 122
6.5 程序复杂程度的定量度量 126
6.5.1McCabe方法 127
6.5.2 Halstead方法 129
6.6 小结 130
习题6 130
第7章 实现 135
7.1 编码 136
7.1.1 选择程序设计语言 136
7.1.2 编码风格 137
7.2 软件测试基础 139
7.2.1 软件测试的目标 140
7.2.2 软件测试准则 140
7.2.3 测试方法 141
7.2.4 测试步骤 141
7.2.5 测试阶段的信息流 142
7.3 单元测试 143
7.3.1 测试重点 143
7.3.2 代码审查 144
7.3.3 计算机测试 145
7.4 集成测试 146
7.4.1 自顶向下集成 147
7.4.2 自底向上集成 148
7.4.3 不同集成测试策略的比较 149
7.4.4 回归测试 150
7.5 确认测试 150
7.5.1 确认测试的范围 150
7.5.2 软件配置复查 151
7.5.3 Alpha和Beta测试 151
7.6 白盒测试技术 152
7.6.1 逻辑覆盖 152
7.6.2 控制结构测试 155
7.7 黑盒测试技术 161
7.7.1 等价划分 162
7.7.2 边界值分析 165
7.7.3 错误推测 165
7.8 调试 166
7.8.1 调试过程 166
7.8.2 调试途径 168
7.9 软件可靠性 169
7.9.1 基本概念 169
7.9.2 估算平均无故障时间的方法 170
7.10 小结 172
习题7 173
第8章维护 179
8.1 软件维护的定义 179
8.2 软件维护的特点 180
8.2.1 结构化维护与非结构化维护差别巨大 180
8.2.2 维护的代价高昂 180
8.2.3 维护的问题很多 181
8.3 软件维护过程 182
8.4 软件的可维护性 185
8.4.1 决定软件可维护性的因素 185
8.4.2 文档 186
8.4.3 可维护性复审 187
8.5 预防性维护 188
8.6 软件再工程过程 188
8.7 小结 191
习题8 192
第9章 面向对象方法学引论 193
9.1 面向对象方法学概述 193
9.1.1 面向对象方法学的要点 193
9.1.2 面向对象方法学的优点 195
9.1.3 喷泉模型 199
9.2 面向对象的概念 200
9.2.1 对象 200
9.2.2 其他概念 202
9.3 面向对象建模 206
9.4 对象模型 207
9.4.1 类图的基本符号 208
9.4.2 表示关系的符号 209
9.5 动态模型 215
9.6 功能模型 215
9.6.1 用例图 215
9.6.2 用例建模 218
9.7 3种模型之间的关系 219
9.8 小结 220
习题9 220
第10章 面向对象分析 223
10.1 面向对象分析的基本过程 223
10.1. 概述 223
10.1.2 3个子模型与5个层次 224
10.2 需求陈述 225
10.2.1 书写要点 225
10.2.2 例子 226
10.3 建立对象模型 227
10.3.1 确定类与对象 228
10.3.2 确定关联 230
10.3.3 划分主题 233
10.3.4 确定属性 233
10.3.5 识别继承关系 236
10.3.6 反复修改 236
10.4 建立动态模型 239
10.4.1 编写脚本 239
10.4.2 设想用户界面 240
10.4.3 画事件跟踪图 241
10.4.4 画状态图 242
10.4.5 审查动态模型 244
10.5 建立功能模型 245
10.5.1 画出基本系统模型图 245
10.5.2 画出功能级数据流图 245
10.5.3 描述处理框功能 246
10.6 定义服务 247
10.7 小结 247
习题10 248
第11章 面向对象设计 249
11.1 面向对象设计的准则 249
11.2 启发规则 251
11.3 软件重用 253
11.3.1 概述 253
11.3.2 类构件 255
11.3.3 软件重用的效益 256
11.4 系统分解 257
11.5 设计问题域子系统 260
11.6 设计人机交互子系统 263
11.7 设计任务管理子系统 265
11.8 设计数据管理子系统 267
11.8.1 选择数据存储管理模式 267
11.8.2 设计数据管理子系统 268
11.8.3 例子 270
11.9 设计类中的服务 270
11.9.1 确定类中应有的服务 270
11.9.2 设计实现服务的方法 271
11.10 设计关联 272
11.11 设计优化 273
11.11.1 确定优先级 273
11.11.2 提高效率的几项技术 274
11.11.3 调整继承关系 275
11.12 小结 277
习题11 278
第12章 面向对象实现 279
12.1 程序设计语言 279
12.1.1 面向对象语言的优点 279
12.1.2 面向对象语言的技术特点 280
12.1.3 选择面向对象语言 284
12.2 程序设计风格 284
12.2.1 提高可重用性 285
12.2.2 提高可扩充性 287
12.2.3 提高健壮性 287
12.3 测试策略 288
12.3.1 面向对象的单元测试 288
12.3.2 面向对象的集成测试 289
12.3.3 面向对象的确认测试 289
12.4 设计测试用例 289
12.4.1 测试类的方法 290
12.4.2 集成测试方法 291
12.5 小结 293
习题12 294
第13章 软件项目管理 295
13.1 估算软件规模 295
13.1.1 代码行技术 295
13.1.2 功能点技术 296
13.2 工作量估算 298
13.2.1 静态单变量模型 298
13.2.2 动态多变量模型 298
13.2.3 COCOMO2模型 299
13.3 进度计划 302
13.3.1 估算开发时间 302
13.3.2 Gantt图 304
13.3.3 工程网络 305
13.3.4 估算工程进度 306
13.3.5 关键路径 308
13.3.6 机动时间 308
13.4 人员组织 310
13.4.1民主制程序员组 310
13.4.2 主程序员组 311
13.4.3 现代程序员组 312
13.5 质量保证 314
13.5.1 软件质量 314
13.5.2 软件质量保证措施 316
13.6 软件配置管理 318
13.6.1软件配置 319
13.6.2 软件配置管理过程 319
13.7 能力成熟度模型 321
13.8 小结 324
习题13 325
附录 327
附录A C++类库管理系统的分析与设计 327
A.1 面向对象分析 327
A.1.1 需求 327
A.1.2 建立对象模型 328
A.2 面向对象设计 329
A.2.1 设计类库结构 329
A.2.2 设计问题域子系统 330
A.2.3 设计人机交互子系统 331
A.2.4 设计其他类 333
附录B 一个汉字行编辑程序的设计 335
B.1 设计规格说明 335
B.1.1 外部编辑命令 335
B.1.2 编辑命令 335
B.1.3 输出信息 336
B.2 概要设计 337
B.2.1 正文文件 337
B.2.2 两个工作模式 339
B.2.3 数据元素 339
B.2.4 过程 340
B.3 概要设计结果 341
B.4 详细设计 344
B.4.1 数据元素 344
B.4.2 控制数据元素 346
B.4.3 编辑过程 346
B.4.4 输入模式的过程 347
B.4.5 编辑模式的过程 348
B.5 详细设计结果 351
B.5.1 编辑程序的详细结构 351
B.5.2 类PASCAL伪码 352
B.5.3 实现编辑程序的算法 354
参考文献 381