代码分析与自动化重构工具集:Modernizing
发布时间 - 2025-07-11 00:00:00 点击率:次遗留系统的现代化演进是一门艺术。
开源和遗留系统现代化工具在日常的软件开发中,我们常常面临一系列问题,例如:
如何解决人类智力不足的问题?模式、原则和工具谁应该解决代码的问题?对于这些问题,一个解决方案是:自动化工具,有些人称之为器。这些工具由一系列的原则与模式支持,将它们融入工具中。另一个解决人成长的方案是:元元(meta-meta),这是另一个故事。
遗留系统是常态。通常,我们遇到的大多数系统都是遗留系统,进入新项目时,可能需要对它们进行快速分析,以提供洞见——写PPT汇报。因此,过去几年,咨询团队也沉淀了一系列的遗留系统分析和重构工具,比如新哥的Tequila、正在开源的架构分析和守护工具ArchGuard等。此外,在某些重构项目中,还需要编写定制的工具来进行分析。
技术热情发电。主要的挑战是,我们需要用自己的业余时间来完善这些工具。
既然要用自己的时间来开发,且与项目无关,这种用爱发电的事情,用开源的方式最合适。
我们需要怎样的工具?从使用工具的结果来看,我们需要的现代化工具是:
可视化驱动。快速生成项目的分析结果,并展示给开发人员了解现状,还有编写PPT。必要的交互性。用于在重构过程中,寻找合适的切入点。定制化开发。特定坏味道。不同的开发团队会有不同的坏味道,有些坏味道无法由Sonarqube这样的工具识别。自动化重构。基于已知的坏味道,对应的代码位置信息,对代码进行自动化重构。适当的语法精准度。更高的语法精准度意味着更高的开发成本,需要有针对性地平衡它们。多平台。我们用的是macOS,而多数时候,客户使用的是Windows。如何开发这样的工具?这里定义的遗留系统现代化工具包括以下几部分:语法分析、结果及可视化、自动化重构、架构守护。
语法分析对代码进行语法分析,生成特定的语言数据结构。常用的工具有:Antlr、Ctags、TreeSitter、Doxygen、CodeQ
uery等。一个大致的对比如下表所示:
结果及可视化通常来说,我们会出于以下的一些情况,来对遗留系统进行可视化:
数值化。如针对于特定的smell进行自动化重构,类似于Sonarqube,常见的模式和原则源自于《重构》一书。在Coca里,还引入了在一些论文中看到的测试的bad smell,例如没有断言的测试等。可视化依赖。如针对于代码中的类、包等的依赖情况进行可视化,主要用于分析分层架构等。常用的工具有:PlantUML、Graphviz、D3.js、Echarts等。代码属性可视化。如针对于文件的修改频率、大小等属性进行可视化,可以获取诸如于单位时间内的文件变化频率。一个文件经常修改,还大量被引用,那说明它是一个不稳定的类、文件,除了业务变化,最有可能就是设计不合理。其它。自动化重构这一步是可选的,它取决于我们的场景。通常来说,编写这样的功能主要弥补现代化的IDE无法完成的工作,例如:
多代码库间的未使用类删除。多代码库间的聚类。针对于CSS颜色的重构。架构守护编写架构的守护规则,以对于系统的架构进行守护,用的工具有:ArchUnit、ArchGuard等。在参考了ArchUnit的语法之后,我们也设计了一个多语言的架构守护工具:Guarding。
在开发这些工具的过程中,它们也在不断推动我进一步学习语言背后的知识,如编译原理(语言的前端部分),理解构建系统(build system)等。
遗留系统现代化工具集为了更有针对性地对遗留系统进行现代化,最近我们创建了一个新的组织:Modernizing,集合了先前开发的一系列工具。并创建了:awesome-modernization用于对其它的一系列相关的工具进行收集。
在Modernizing里,针对单个编程语言的工具有:
针对Java语言的系统重构、系统迁移和系统分析工具:Coca,Go语言,GitHub stars:691。Coca是一个“全功能”的重构工具,基于Antlr进行语法分析的,除了常规的可视化、调用分析,还可以进行自动化重构。Coca一名的由来是:对标新哥写的Tequila——龙舌兰酒vs快乐水。针对CSS/LESS/CSS的分析和自动化重构工具:Lemonj,TypeScript语言,GitHub stars:128。当初设计的主要目的是:用来对CSS中的颜色进行提取,基于Antlr的语法树分析,可以用于进行自动化的重构。针对MySQL代码进行自动化分析,并从中构建UML,并生成其关系的:SQLing,Go语言,使用PingCap的SQL解析器解析。当然了,还有一个初始化的针对PL/SQL的版本:pling。适用于Ant转Maven的半自动化工具:Merry,Go语言+Antlr。前端规范化改造工具:Clij,用于一键添加eslint、husky、lint-staged等,TypeScript语言。针对多语言的工具,我们有:
基于Antlr的多语言的语言模型分析工具:Chapi,Kotlin语言。其设计的初衷是用于生成Coca相同的数据结构,以接入更多的可视化工具。在语法分析上,采用的是Antlr进行分析。基于Doxygen的多语言分析和可视化工具:Go mod版本的新哥的Tequila。其中,还有一系列的迷之代码,需要重构掉。基于Ctags的多语言模型分析和可视化工具:Modeling,Rust语言。分析源码,并生成基于模型的可视化依赖。基于TreeSitter的多语言架构守护工具:Guarding,Rust语言。通过自制的DSL,来对系统架构进行守护。除此,还有一个在Inherd开源小组下开源的:Coco,它主要是通过代码的物理属性:修改频率+目录+行数来分析系统的工具。以及现在紧锣密鼓开源中的ArchGuard。
我们使用一系列不同的语言和工具来开发这些软件,因为不同的场景下,都会有不同的选择。
下一步?现有的工具都是分散的,不同工具之间的数据格式不尽相同,缺乏统一的数据格式。在输出格式不统一时,我们就难以进行标准的可视化,例如我们正在构建codecity用于在元宇宙里,对遗留系统进行可视化,又或者是正在从ArchGuard中拆分的前端可视化部分,以用于复用。理想的情况下,它应该像是一个pipeline架构的系统,由一系列的pipe和filter所构成。
# apache
# css
# mysql
# git
# typescript
# windows
# go语言
# 工具
# macos
# 元宇宙
# Java
# kotlin
# rust
# sql
# 架构
# echarts
# less
# maven
# Filter
# 数据结构
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
高端建站三要素:定制模板、企业官网与响应式设计优化
如何用搬瓦工VPS快速搭建个人网站?
laravel怎么用DB facade执行原生SQL查询_laravel DB facade原生SQL执行方法
Python自然语言搜索引擎项目教程_倒排索引查询优化案例
Laravel如何使用Blade模板引擎?(完整语法和示例)
iOS正则表达式验证手机号、邮箱、身份证号等
历史网站制作软件,华为如何找回被删除的网站?
深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?
如何在IIS服务器上快速部署高效网站?
瓜子二手车官方网站在线入口 瓜子二手车网页版官网通道入口
如何快速搭建高效香港服务器网站?
Win11关机界面怎么改_Win11自定义关机画面设置【工具】
js实现点击每个li节点,都弹出其文本值及修改
EditPlus中的正则表达式 实战(1)
详解MySQL数据库的安装与密码配置
企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?
太平洋网站制作公司,网络用语太平洋是什么意思?
HTML 中如何正确使用模板变量为元素的 name 属性赋值
实现点击下箭头变上箭头来回切换的两种方法【推荐】
黑客如何利用漏洞与弱口令入侵网站服务器?
Mybatis 中的insertOrUpdate操作
Angular 表单中正确绑定输入值以确保提交与验证正常工作
详解Android——蓝牙技术 带你实现终端间数据传输
Laravel怎么实现搜索功能_Laravel使用Eloquent实现模糊查询与多条件搜索【实例】
微信小程序制作网站有哪些,微信小程序需要做网站吗?
Laravel如何使用Vite进行前端资源打包?(配置示例)
详解jQuery中的事件
Laravel怎么集成Log日志记录_Laravel单文件与每日日志配置及自定义通道【详解】
香港服务器部署网站为何提示未备案?
昵图网官方站入口 昵图网素材图库官网入口
Laravel如何保护应用免受CSRF攻击?(原理和示例)
使用C语言编写圣诞表白程序
微信小程序 input输入框控件详解及实例(多种示例)
Laravel Session怎么存储_Laravel Session驱动配置详解
制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?
魔毅自助建站系统:模板定制与SEO优化一键生成指南
Laravel模型事件有哪些_Laravel Model Event生命周期详解
如何在阿里云域名上完成建站全流程?
1688铺货到淘宝怎么操作 1688一键铺货到自己店铺详细步骤
大学网站设计制作软件有哪些,如何将网站制作成自己app?
Laravel如何实现数据库事务?(DB Facade示例)
jQuery 常见小例汇总
专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?
googleplay官方入口在哪里_Google Play官方商店快速入口指南
Laravel路由怎么定义_Laravel核心路由系统完全入门指南
javascript中的数组方法有哪些_如何利用数组方法简化数据处理
Laravel如何生成和使用数据填充?(Seeder和Factory示例)
谷歌浏览器如何更改浏览器主题 Google Chrome主题设置教程
Laravel如何生成PDF或Excel文件_Laravel文档导出工具与使用教程
UC浏览器如何设置启动页 UC浏览器启动页设置方法

