博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
软件架构之RUP 4+1视图模型
阅读量:6798 次
发布时间:2019-06-26

本文共 931 字,大约阅读时间需要 3 分钟。

一个架构视图是对于从某一视角或某一点上看到的系统所做的简化描述,描述中涵盖了系统的某一特定方面,而省略了于此方面无关的实体。

也就是说,架构要涵盖的内容和决策太多了,超过了人脑"一蹴而就"的能力范围,因此采用"分而治之"的办法从不同视角分别设计;同时,也为软件架构的理解、交流和归档提供了方便。

1995年,Philippe Kruchten在《IEEE Software》上发表了题为《The 4+1 View Model of Architecture》的论文,引起了业界的极大关注,并最终被RUP采纳。如图所示。

软件架构之RUP 4+1视图模型

该方法的不同架构视图承载不同的架构设计决策,支持不同的目标和用途:

  • 逻辑视图:当采用面向对象的设计方法时,逻辑视图即对象模型。
  • 开发视图:描述软件在开发环境下的静态组织。
  • 处理视图:描述系统的并发和同步方面的设计。
  • 物理视图:描述软件如何映射到硬件,反映系统在分布方面的设计。
    软件架构之RUP 4+1视图模型

逻辑视图。逻辑视图关注功能,不仅包括用户可见的功能,还包括为实现用户功能而必须提供的"辅助功能模块";它们可能是逻辑层、功能模块等。

开发视图。开发视图关注程序包,不仅包括要编写的源程序,还包括可以直接使用的第三方SDK和现成框架、类库,以及开发的系统将运行于其上的系统软件或中间件。开发视图和逻辑视图之间可能存在一定的映射关系:比如逻辑层一般会映射到多个程序包等。

处理视图。处理视图关注进程、线程、对象等运行时概念,以及相关的并发、同步、通信等问题。处理视图和开发视图的关系:开发视图一般偏重程序包在编译时期的静态依赖关系,而这些程序运行起来之后会表现为对象、线程、进程,处理视图比较关注的正是这些运行时单元的交互问题。

物理视图。物理视图关注"目标程序及其依赖的运行库和系统软件"最终如何安装或部署到物理机器,以及如何部署机器和网络来配合软件系统的可靠性、可伸缩性等要求。物理视图和处理视图的关系:处理视图特别关注目标程序的动态执行情况,而物理视图重视目标程序的静态位置问题;物理视图是综合考虑软件系统和整个IT系统相互影响的架构视图。

更多可参考:

1)
2)

转载于:https://blog.51cto.com/dengshuangfu/2356183

你可能感兴趣的文章
C 二维数组与指针
查看>>
信息安全系统设计基础第四周学习总结
查看>>
node c++ addon注意事项
查看>>
hdu 3501(欧拉函数引申)
查看>>
django-request获取数据
查看>>
python的eval、exec函数使用总结
查看>>
js解析与序列化json数据(一)
查看>>
struts2 里面OpenSessionInViewFilter(转)
查看>>
Oracle升级前备份和失败回退
查看>>
linux常用服务部署
查看>>
RabbitMQ基础总结
查看>>
java获取properties配置文件中某个属性最简单方法
查看>>
POJ1321 棋盘问题
查看>>
5/27 C语言 指针系列
查看>>
SSL协议握手过程
查看>>
博客阅读和思考
查看>>
学习笔记之PostgreSQL / pgAdmin / Psycopg / PostGIS
查看>>
Linux Timer定时器【转】
查看>>
java设计模式-工厂方法模式
查看>>
SAP RFC通信模式
查看>>