当前位置:首页 > 科技  > 软件

利用依赖结构矩阵管理架构债务

来源: 责编: 时间:2024-07-09 18:19:45 916观看
导读技术债务(Technical Debt)是软件开发的热门话题,随着时间推移,源代码逐渐增多,技术债务也变得越来越复杂。有很多分析技术债务的工具,基本上都专注于代码质量。架构债务是技术债务的一部分,但由于没有像技术债务那样的自动化

技术债务(Technical Debt)是软件开发的热门话题,随着时间推移,源代码逐渐增多,技术债务也变得越来越复杂。有很多分析技术债务的工具,基本上都专注于代码质量。架构债务是技术债务的一部分,但由于没有像技术债务那样的自动化工具,因此并不容易确定。ONI28资讯网——每日最新资讯28at.com

ONI28资讯网——每日最新资讯28at.com

在确定架构债务时,应研究与源代码耦合的"架构反模式"。以下是需要确定和消除的常见架构反模式:ONI28资讯网——每日最新资讯28at.com

  • 不稳定接口:这些接口通常是系统的应用程序接口或入口点,有许多依赖组件,接口的微小改动都会让所有依赖组件头疼不已。
  • 违反模块化原则:软件系统应采用模块化架构。这意味着可变更组件应架构在同一模块中,以避免模块间的依赖。如果一个模块的变化对其他模块产生了巨大影响,就应该研究这一不稳定的根本原因。
  • 不健康的继承:当超类依赖于子类或调用者类依赖于超类和子类实例时,就会出现这种情况。
  • 循环依赖:例如,当组件 A 依赖于组件 B,而组件 B 又依赖于组件 C,组件 C 又依赖于组件 A,就产生了循环依赖。这种情况应通过"依赖倒置原则(Dependency Inversion Principle)"加以避免。
  • 软件包循环:多个软件包或插件混乱的相互依赖,而不是形成等级依赖关系。
  • 交叉:依赖于多个其他类的上帝类,另一方面,众多不同的类又依赖于这个特定的类。

为了避免这些架构反模式,软件架构师应考虑实施 S.O.L.I.D.原则、GoF 设计模式、耦合原则/组件原则。ONI28资讯网——每日最新资讯28at.com

下面是示例性现金流 Spring Boot 应用的 UML,可以在 git 仓库[2]中查看源代码。如你所见,该项目由三个基础包构成:api、core、database,采用分层模式。api负责向外部调用者公开restful API,core包含内部所有与业务相关的代码,而database则专注于数据库层。ONI28资讯网——每日最新资讯28at.com

ONI28资讯网——每日最新资讯28at.com

现金流应用程序的 UML 图ONI28资讯网——每日最新资讯28at.com

在研究了现金流应用程序的 UML 图之后,我们来生成系统的依赖结构矩阵(Dependency Structure Matrix)。我通过 Jarchitect[3] 工具生成矩阵,但此外还有很多替代方法:如 Intellij 或 Ndepend[4] 的 DSM[5] 支持。列和行代表 Spring Boot 应用程序 src 文件夹中的 Java 类,它们的结构是对称的。第 8 列是 IncomeService,与第 8 行对应的是相同的类/接口。单元格中的数字表示类之间的静态依赖导入。例如第 12 列(ConverterServiceImpl.java)在第4/5/10行中标了1,表示该类实现了 ConverterService、ExpenseConverterService、Service.ONI28资讯网——每日最新资讯28at.com

ONI28资讯网——每日最新资讯28at.com

现金流应用的依赖结构矩阵ONI28资讯网——每日最新资讯28at.com

为了通过 DSM 找到架构债务,人们应该寻找:ONI28资讯网——每日最新资讯28at.com

  • 循环调用:A 类调用 B 类,B 类调用 A 类
  • 交叉:数字大的单元格意味着依赖关系多
  • 数字应围绕对角线分配:意味着类具有很强的内凝性
  • 矩阵中的数字越混乱,意味着依赖结构越不安全
  • 评估 S.O.L.I.D 原则,研究持有接口的列数

参考资料:ONI28资讯网——每日最新资讯28at.com

  • [1]Managing Architecture Debt with Dependency Structure Matrix:https://readmedium.com/51f63b6efb4c
  • [2]SOLID Principles Sample: https://github.com/alizeynalli90/solid-principles
  • [3]Jarchitect: https://www.jarchitect.com
  • [4]Ndepend: https://www.ndepend.com
  • [5]DSM: https://www.jetbrains.com/help/idea/dsm-analysis.html

本文链接:http://www.28at.com/showinfo-26-99898-0.html利用依赖结构矩阵管理架构债务

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Python 新手必学:创建文件的五种方法

下一篇: InheritableThreadLocal 是如何实现的父子线程局部变量的传递

标签:
  • 热门焦点
  • Find N3入网:最高支持16+1TB

    OPPO将于近期登场的Find N3折叠屏目前已经正式入网,型号为PHN110。本次Find N3在外观方面相比前两代有很大的变化,不再是小号的横向折叠屏,而是跟别的厂商一样采用了较为常见的
  • 印度登月最关键一步!月船三号今晚进入环月轨道

    8月5日消息,据印度官方消息,月船三号将于北京时间今晚21时30分左右开始近月制动进入环月轨道。这是该探测器能够成功的最关键步骤之一,如果成功将开始围
  • 使用LLM插件从命令行访问Llama 2

    最近的一个大新闻是Meta AI推出了新的开源授权的大型语言模型Llama 2。这是一项非常重要的进展:Llama 2可免费用于研究和商业用途。(几小时前,swyy发现它已从LLaMA 2更名为Lla
  • 三分钟白话RocketMQ系列—— 如何发送消息

    我们知道RocketMQ主要分为消息 生产、存储(消息堆积)、消费 三大块领域。那接下来,我们白话一下,RocketMQ是如何发送消息的,揭秘消息生产全过程。注意,如果白话中不小心提到相关代
  • 大厂卷向扁平化

    来源:新熵作者丨南枝 编辑丨月见大厂职级不香了。俗话说,兵无常势,水无常形,互联网企业调整职级体系并不稀奇。7月13日,淘宝天猫集团启动了近年来最大的人力制度改革,目前已形成一
  • 超闭合精工铰链 彻底消灭缝隙 三星Galaxy Z Flip5与Galaxy Z Fold5发布

    2023年7月26日,三星电子正式发布了Galaxy Z Flip5与Galaxy Z Fold5。三星新一代折叠屏手机采用超闭合精工铰链,让折叠后的缝隙不再可见。同时,配合处
  • iQOO Neo8系列新品发布会

    旗舰双芯 更强更Pro
  • Android 14发布:首批适配机型公布

    5月11日消息,谷歌在今天凌晨举行了I/O大会,本次发布会谷歌带来了自家的AI语言模型PaLM 2、谷歌Pixel Fold折叠屏、谷歌Pixel 7a手机,同时发布了Androi
  • 质感不错!OPPO K11渲染图曝光:旗舰IMX890传感器首次下放

    一直以来,OPPO K系列机型都保持着较为均衡的产品体验,历来都是2K价位的明星机型,去年推出的OPPO K10和OPPO K10 Pro两款机型凭借各自的出色配置,堪称有
Top