IntelliJ IDEA的DSM工具使架构可视化

优良架构的一个重要特点就是通过组件分层使模块间的依赖流畅贯穿于整个架构。如何描述和维护组件间的依赖是一个常见却又很难解决的工作。UML包图(package diagram)提供了描述这种依赖的方法,但是创建包图往往很耗费时间,甚至在反向工程时,获得一个直观的设计也需要很长的时间。此外,UML也不能有效地进行修正,用它来维护大型且复杂的系统的依赖图,投资回报率往往很小。

依赖结构矩阵(Dependency Structure Matrices,DSM),这一较新技术的出现填补了这个空白。DSM是一个矩阵,其中每行是一个模块,列则在另一维度上显示一组同样的模块。每个单元格表示两个模块之间的交集,以及它们之间依赖的数目。不需要任何更多的信息,一个人通过典型的例子就能迅速且直观地看到漂亮的DSM可视化图。

匆匆一瞥之后我们接着来看,每行代表分层架构中的一个包。这些行依次从1到5进行编号。列也依次编号为1至5,分别表示与行同样的模块。在严格分层系统中,application只依赖于model(37次),model只依赖于domain,等等。在分层系统中,上层(比如application)可以依赖于其下任何一层(比如util)。有了这种可视化图,只要代码编写违反了规则,可视化图就会立即反映出来。任何出现在右上方的依赖都表明违反了架构的意图。

IntelliJ已经在新版本“Magnificent 7”中引入了新的DSM工具。不用考虑代码基线(codebase)的分层,不用手动整理UML图,IntelliJ会自动从一个已存在的工程生成DSM。像其它DSM工具一样,IntelliJ能自动调整节点,使依赖显示在左下方。DSM是交互式的,可以下钻到类级别:

在这个例子中,IntelliJ的DSM工具表明,ReferenceStrength在架构中,被其下层使用了4次。将DSM工具集成到IDE中非常方便。IDEA能非常容易地显示出代码基线中的4次引用,使问题容易地被修复。在这种情况下,可以使用IntelliJ的重构工具把ReferenceStrength移到一个更高层次的包中。

你可能感兴趣的:(IntelliJ IDEA的DSM工具使架构可视化)