InfoQ

新闻

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

作者 Michael Bushe译者 王丽娟 发布于 2008年2月20日 上午12时24分

社区
Architecture
主题
工件和工具,
代码分析
标签
IntelliJ IDEA,
视觉化

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

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

DSM of a layered system

  分层系统的DSM

DSM of a strictly layered system.

严格分层系统的DSM

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

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

DSM for the EventBus, drilled to the class level

EventBus库的IntelliJ DSM

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

navigation to the broken dependency

IntelliJ的DSM工具还有改进的余地。例如,IDEA并没有利用前面提及的已编号的行和列来进一步提高其可用性。而其它工具,比如说Lattix,则有更为强大的重构支持。Lattix可以从矩阵的可视化图中直接移动类或包。

Lattix Refactoring

Lattix重构 
DSM作为一个强大的工具,正在走上更多从业者的桌面。
查看英文原文IntelliJ IDEA's Dependency Structure Matrix Tool Visualizes Architecture

没有回复

回复

独家内容

剖析短迭代

敏捷教练Dave Nicolette提出:我们应该如何设定迭代长度?是要根据发布周期的时间么?使用短迭代又有哪些好处?

应用JSF、Ajax和Seam开发Portlets(1/3)

本文主要讲述了如何用JBoss Portlet Container 和JBoss Portlet Bridge创建新项目,怎样配置一个JSF应用去使用JBoss Portlet Bridge,以及JBoss Portlet Bridge所具备的功能。

AtomServer:数据分发的发布动力(第二部分)

在这篇文章里,Bryon Jacob和Chris Berry将和我们继续探讨AtomServer,它是基于Apache Abdera的完整Atom存储实现。作者还创建了几个Atompub规范扩展,其中包括自动标记、批处理和Feeds聚合。

架构师(试刊第二期)

InfoQ中文站的电子杂志《架构师》试刊第二期出版了!相比于上期,我们在内容的选择安排和版式上都根据读者的意见重新做了修正。“细节决定成败”,我们希望基于InfoQ中文站的专业内容,《架构师》能逐渐成为大家喜欢的电子刊物!

一种正规的性能调优方法:基于等待的调优

在本文中,Steven Haines探讨了Web应用性能调优问题。该领域过去更像是一门艺术而不是一门科学。他提出了一种称为基于等待调优的方法,使整个调优过程更加可度量,也因此更具科学性。

Java程序员ActionScript 3入门

通常来说,改变技术路线时最艰难的部分是辨别语言语法之间的不同。这篇文章就为Java开发者提供了一份如何转向Flex基础语言ActionScript的指南。

浅谈如何创建Rails应用

本视频主要以财帮子为例,介绍了如何创建一个PV为百万级的Rails应用。其中包括:Rails应用的服务器架构、Rails Cache的优化、负载均衡的处理、Web服务器的调试、分布式解决方案、Open API的设计等等。

Alexandru Popescu谈InfoQ.com网站架构

InfoQ首席架构师Alexandru Popescu在采访中谈论了InfoQ架构、Webwork与DWR、Hibernate与JCR、Hibernate可扩展性、最新的InfoQ视频流系统和InfoQ的未来规划。