0

0

代码分析与自动化重构工具集:Modernizing

蓮花仙者

蓮花仙者

发布时间:2025-07-11 10:32:12

|

272人浏览过

|

来源于php中文网

原创

遗留系统的现代化演进是一门艺术。

开源和遗留系统现代化工具在日常的软件开发中,我们常常面临一系列问题,例如:

如何解决人类智力不足的问题?模式、原则和工具谁应该解决代码的问题?对于这些问题,一个解决方案是:自动化工具,有些人称之为器。这些工具由一系列的原则与模式支持,将它们融入工具中。另一个解决人成长的方案是:元元(meta-meta),这是另一个故事。

遗留系统是常态。通常,我们遇到的大多数系统都是遗留系统,进入新项目时,可能需要对它们进行快速分析,以提供洞见——写PPT汇报。因此,过去几年,咨询团队也沉淀了一系列的遗留系统分析和重构工具,比如新哥的Tequila、正在开源的架构分析和守护工具ArchGuard等。此外,在某些重构项目中,还需要编写定制的工具来进行分析。

技术热情发电。主要的挑战是,我们需要用自己的业余时间来完善这些工具。

既然要用自己的时间来开发,且与项目无关,这种用爱发电的事情,用开源的方式最合适。

我们需要怎样的工具?从使用工具的结果来看,我们需要的现代化工具是:

可视化驱动。快速生成项目的分析结果,并展示给开发人员了解现状,还有编写PPT。必要的交互性。用于在重构过程中,寻找合适的切入点。定制化开发。特定坏味道。不同的开发团队会有不同的坏味道,有些坏味道无法由Sonarqube这样的工具识别。自动化重构。基于已知的坏味道,对应的代码位置信息,对代码进行自动化重构。适当的语法精准度。更高的语法精准度意味着更高的开发成本,需要有针对性地平衡它们。多平台。我们用的是macOS,而多数时候,客户使用的是Windows。如何开发这样的工具?这里定义的遗留系统现代化工具包括以下几部分:语法分析、结果及可视化、自动化重构、架构守护。

代码分析与自动化重构工具集:Modernizing语法分析对代码进行语法分析,生成特定的语言数据结构。常用的工具有:Antlr、Ctags、TreeSitter、Doxygen、CodeQuery等。一个大致的对比如下表所示:

代码分析与自动化重构工具集:Modernizing结果及可视化通常来说,我们会出于以下的一些情况,来对遗留系统进行可视化:

数值化。如针对于特定的smell进行自动化重构,类似于Sonarqube,常见的模式和原则源自于《重构》一书。在Coca里,还引入了在一些论文中看到的测试的bad smell,例如没有断言的测试等。可视化依赖。如针对于代码中的类、包等的依赖情况进行可视化,主要用于分析分层架构等。常用的工具有:PlantUML、Graphviz、D3.js、Echarts等。代码属性可视化。如针对于文件的修改频率、大小等属性进行可视化,可以获取诸如于单位时间内的文件变化频率。一个文件经常修改,还大量被引用,那说明它是一个不稳定的类、文件,除了业务变化,最有可能就是设计不合理。其它。自动化重构这一步是可选的,它取决于我们的场景。通常来说,编写这样的功能主要弥补现代化的IDE无法完成的工作,例如:

聚好用AI
聚好用AI

可免费AI绘图、AI音乐、AI视频创作,聚集全球顶级AI,一站式创意平台

下载

多代码库间的未使用类删除。多代码库间的聚类。针对于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所构成。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

49

2026.02.13

TypeScript全栈项目架构与接口规范设计
TypeScript全栈项目架构与接口规范设计

本专题面向全栈开发者,系统讲解基于 TypeScript 构建前后端统一技术栈的工程化实践。内容涵盖项目分层设计、接口协议规范、类型共享机制、错误码体系设计、接口自动化生成与文档维护方案。通过完整项目示例,帮助开发者构建结构清晰、类型安全、易维护的现代全栈应用架构。

196

2026.02.25

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

62

2026.03.13

Kotlin协程编程与Spring Boot集成实践
Kotlin协程编程与Spring Boot集成实践

本专题围绕 Kotlin 协程机制展开,深入讲解挂起函数、协程作用域、结构化并发与异常处理机制,并结合 Spring Boot 展示协程在后端开发中的实际应用。内容涵盖异步接口设计、数据库调用优化、线程资源管理以及性能调优策略,帮助开发者构建更加简洁高效的 Kotlin 后端服务架构。

128

2026.02.12

C++系统编程内存管理_C++系统编程怎么与Rust竞争内存安全
C++系统编程内存管理_C++系统编程怎么与Rust竞争内存安全

C++系统编程中的内存管理是指 对程序运行时内存的申请、使用和释放进行精细控制的机制,涵盖了栈、堆、静态区等不同区域,开发者需要通过new/delete、智能指针或内存池等方式管理动态内存,以避免内存泄漏、野指针等问题,确保程序高效稳定运行。它核心在于开发者对低层内存有完全控制权,带来灵活性,但也伴随高责任,是C++性能优化的关键。

13

2025.12.22

Rust异步编程与Tokio运行时实战
Rust异步编程与Tokio运行时实战

本专题聚焦 Rust 语言的异步编程模型,深入讲解 async/await 机制与 Tokio 运行时的核心原理。内容包括异步任务调度、Future 执行模型、并发安全、网络 IO 编程以及高并发场景下的性能优化。通过实战示例,帮助开发者使用 Rust 构建高性能、低延迟的后端服务与网络应用。

10

2026.02.11

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

233

2026.03.05

数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1135

2023.10.12

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

49

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
RunnerGo从入门到精通
RunnerGo从入门到精通

共22课时 | 1.8万人学习

尚学堂Mahout视频教程
尚学堂Mahout视频教程

共18课时 | 3.3万人学习

Linux优化视频教程
Linux优化视频教程

共14课时 | 3.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号