优良架构的一个重要特点就是通过组件分层使模块间的依赖流畅贯穿于整个架构。如何描述和维护组件间的依赖是一个常见却又很难解决的工作。UML包图(package diagram)提供了描述这种依赖的方法,但是创建包图往往很耗费时间,甚至在反向工程时,获得一个直观的设计也需要很长的时间。此外,UML也不能有效地进行修正,用它来维护大型且复杂的系统的依赖图,投资回报率往往很小。
依赖结构矩阵(Dependency Structure Matrices,DSM),这一较新技术的出现填补了这个空白。DSM是一个矩阵,其中每行是一个模块,列则在另一维度上显示一组同样的模块。每个单元格表示两个模块之间的交集,以及它们之间依赖的数目。不需要任何更多的信息,一个人通过典型的例子就能迅速且直观地看到漂亮的DSM可视化图。
![]() |
| 图1:分层系统的DSM |
![]() |
| 图2:严格分层系统的DSM |
匆匆一瞥之后我们接着来看,每行代表分层架构中的一个包。这些行依次从1到5进行编号。列也依次编号为1至5,分别表示与行同样的模块。在严格分层系统中,application只依赖于model(37次),model只依赖于domain,等等。在分层系统中,上层(比如application)可以依赖于其下任何一层(比如util)。有了这种可视化图,只要代码编写违反了规则,可视化图就会立即反映出来。任何出现在右上方的依赖都表明违反了架构的意图。
IntelliJ已经在新版本“Magnificent 7”中引入了新的DSM工具。不用考虑代码基线(codebase)的分层,不用手动整理UML图,IntelliJ会自动从一个已存在的工程生成DSM。像其它DSM工具一样,IntelliJ能自动调整节点,使依赖显示在左下方。DSM是交互式的,可以下钻到类级别:
![]() |
| 图3:EventBus库的IntelliJ DSM |
在这个例子中,IntelliJ的DSM工具表明,ReferenceStrength在架构中,被其下层使用了4次。将DSM工具集成到IDE中非常方便。IDEA能非常容易地显示出代码基线中的4次引用,使问题容易地被修复。在这种情况下,可以使用IntelliJ的重构工具把ReferenceStrength移到一个更高层次的包中。
![]() |
| 图4 |
IntelliJ的DSM工具还有改进的余地。例如,IDEA并没有利用前面提及的已编号的行和列来进一步提高其可用性。而其它工具,比如说Lattix,则有更为强大的重构支持。Lattix可以从矩阵的可视化图中直接移动类或包。
![]() |
| 图5:Lattix重构 |
DSM作为一个强大的工具,正在走上更多从业者的桌面。
原文链接:http://www.infoq.com/cn/news/2008/02/idea-dependency-structure-matrix
|
||||
| · Sun以10亿美元并购开源.. · 运营商封堵非法ADSL共享 · 珊瑚虫QQ作者侵权案开庭 · Windows Server 2008 · SQL Server 2008/2005.. · 打造安全网络环境 · 网络安全产品检验规范 · 社会工程学与网络安全 |
· 离职员工安全隐患 · 杀毒软件评测专题 · 中间件应用技术专题 · 杀毒软件优化和使用技巧 · 信息安全等级保护专题 · 补丁自动分发管理策略.. · 杀毒王牌 · AMD Phenom三核处理器.. |
|||
|
||||
| · VPN技术 · SQL Server 2008/2005.. · SOA 面向服务架构 · 子网掩码教程 · SQL Server 2008/2005.. · 中间件应用技术专题 · 深入了解PGP加密技术 · MySQL数据库备份 |
· 病毒查杀专题 · VPN技术 · Solaris 10 配置管理 · Linux 基础 · SSL VPN详细知识 · Linux防火墙 · 路由器设置与口令恢复 · Linux 集群技术专题 |
|||
|
||||
| · VPN技术 · SQL Server 2008/2005.. · 中间件应用技术专题 · SQL Server 2008/2005.. · SOA 面向服务架构 · 子网掩码教程 · MySQL数据库备份 · 身份认证技术 |
· 病毒查杀专题 · 清除流氓软件——51CTO.. · SSL VPN详细知识 · Sniffer安全技术从入门.. · 常用交换机典型配置 · 路由器设置与口令恢复 · Linux 集群技术专题 · VPN技术 |
|||