软件工程中的功能分解与开发模型探讨

需积分: 44 13 下载量 75 浏览量 更新于2024-08-19 收藏 1.4MB PPT 举报
"功能分解方法-中国矿业大学-2015级-软件工程复习PPT" 功能分解方法是软件工程中需求分析阶段的一种常用技术,它将一个复杂的系统视为由多个功能模块组成的集合,每个模块可以进一步分解为更小的子功能。这种层次化的分解有助于清晰地组织和理解系统的各个组成部分,从而构建出系统的初步架构。然而,功能分解方法存在一些问题:首先,它依赖人工完成,可能导致分解的主观性和不完整性;其次,没有机制来验证功能描述的准确性,可能引发理解偏差;最后,面对需求变化时,原有的功能分解结构可能难以适应,需要大量调整。 在软件工程的历史中,软件危机是一个持续存在的问题,从20世纪60年代至今,如美国范登堡基地火箭发射失败和Therac-25医疗设备事故,都揭示了软件错误可能导致的重大损失。软件开发过程中的不透明性和难以量化的问题,常常被比喻为“皇帝的新衣”,因为软件的逻辑大部分存在于开发者的思维中,而非可见的实体。 软件工程试图通过一系列环节来解决这些问题,包括人员管理、项目管理、需求分析、系统设计、程序设计、测试和维护等。这些环节应当按照一定的流程相互连接,形成标准化的操作,就像工厂的生产线。早期的开发模式,如“作坊式开发”,强调快速编写和修改代码,缺乏规划和设计,容易导致软件结构逐渐恶化,难以维护。 为了改进这种状况,Winston Royce在1970年提出了“瀑布模型”,这是一种线性的开发模型,按照制定计划、需求分析、设计、编码、测试和维护的顺序进行,每一步都依赖前一步的结果。然而,瀑布模型对于需求不明确或变化频繁的情况显得僵化,容易造成开发风险。 为了解决瀑布模型的不足,演进模型(或迭代模型)应运而生。它允许在开发过程中创建和改进原型,逐步完善软件,降低了因需求不明确带来的风险。通过多次迭代,开发者能够更准确地理解和满足用户需求,从而构建出更符合实际的软件产品。 功能分解方法是需求分析的重要工具,但需结合其他软件工程实践,如瀑布模型和演进模型,以适应不同项目的需求和变化。在软件开发过程中,良好的需求管理、系统设计和持续的反馈与改进是避免软件危机的关键。