10.1 软件架构演化和定义的关系 ★★★☆☆
10.1.1 演化的重要性
软件架构的演化就是软件整体结构的演化,演化过程涵盖软件架构的全生命周期,包括软件架构需求的获取、软件架构建模、软件架构文档、软件架构实现以及软件架构维护等阶段。
首先,软件架构作为软件系统的骨架支撑着整个软件系统,是软件系统具备诸多好的特性的重要保障。
其次,软件架构作为软件蓝图为人们宏观管控软件系统的整体复杂性和变化性提供了一条有效途径,而且基于软件架构进行的软件检测和修改成本相对较低
10.1.2 演化和定义的关系
软件架构包括组件 (Components)、 连接件 (Connectors) 和约束 (Constraints) 三大要素,主要关注的就是组件、连接件和约束的添加、修改与删除等。
组件是软件架构的基本要素和结构单元,表示系统中主要的计算元素、数据存储以及一些重要模块。组件的演化体现在组件中模块的增加、删除或修改。通常模块的改动会影响交互消息的变动。
连接件是组件之间的交互关系,大多数情况下组件的演化牵涉到连接件的演化。连接件的演化体现在组件交互消息的增加、删除或改变,以及组件之间交互消息的增加、删除或改变。
约束是组件和连接件之间的拓扑关系和配置,它为组件和连接件提供额外数据支撑,可以是架构的约束数据,也可以是架构的参数。约束的演化体现在知识库中仿真数据的增加、删除 或改变。
组件、连接件、约束的演化都可能导致一系列的波及效应,从而分为受变更直接影响的组件、连接件、约束,以及受到变更波及的组件、连接件、约束两类变更元素。这两类变更元素和不受影响的元素共同组成了演化后的软件架构。