PMD 静态代码分析器使用教程
2024-08-10 01:20:21作者:宣海椒Queenly
项目介绍
PMD 是一个可扩展的多语言静态代码分析器。它能够发现常见的编程缺陷,如未使用的变量、空的 catch 块、不必要的对象创建等。PMD 主要关注 Java 和 Apex 语言,但也支持其他 16 种语言。它内置了 400 多个规则,并且可以通过自定义规则进行扩展。PMD 使用 JavaCC 和 Antlr 将源文件解析为抽象语法树(AST),并运行规则以发现违规行为。
项目快速启动
安装 PMD
在 Linux 或 MacOS 上安装
$ cd $HOME
$ wget https://github.com/pmd/pmd/releases/download/pmd_releases%2F7.4.0/pmd-dist-7.4.0-bin.zip
$ unzip pmd-dist-7.4.0-bin.zip
$ alias pmd="$HOME/pmd-bin-7.4.0/bin/pmd"
$ pmd check -d /usr/src -R rulesets/java/quickstart.xml -f text
在 Windows 上安装
-
下载并解压 PMD 压缩包:
$ cd $HOME $ curl -OL https://github.com/pmd/pmd/releases/download/pmd_releases%2F7.4.0/pmd-dist-7.4.0-bin.zip $ unzip pmd-dist-7.4.0-bin.zip -
将 PMD 添加到系统 PATH 中:
- 永久添加:使用系统属性对话框 > 环境变量 > 追加到 PATH 变量
- 临时添加:在命令行中执行
SET PATH=C:\pmd-bin-7.4.0\bin;%PATH%
-
运行 PMD:
$ pmd.bat check -d c:\src -R rulesets/java/quickstart.xml -f text
使用 PMD 进行代码检查
$ pmd check -d /path/to/your/source -R rulesets/java/quickstart.xml -f text
应用案例和最佳实践
案例一:Java 项目代码质量提升
在一个 Java 项目中,使用 PMD 进行代码质量检查,发现并修复了多个未使用的变量和空的 catch 块。通过定期运行 PMD,项目代码质量得到了显著提升。
案例二:Apex 代码优化
在 Salesforce 项目中,使用 PMD 对 Apex 代码进行分析,发现了一些不必要的对象创建和冗余代码。通过优化这些代码,提高了代码的执行效率和可维护性。
最佳实践
- 定期运行 PMD:建议在持续集成(CI)流程中定期运行 PMD,以确保代码质量。
- 自定义规则:根据项目需求,编写自定义规则以满足特定的代码检查需求。
- 结合其他工具:将 PMD 与其他静态代码分析工具(如 Checkstyle、FindBugs)结合使用,以获得更全面的代码质量报告。
典型生态项目
PMD Designer
PMD Designer 是一个用于创建和测试 PMD 自定义规则的工具。它提供了直观的界面,帮助开发者编写和调试规则。
PMD Eclipse 插件
PMD Eclipse 插件允许开发者在 Eclipse IDE 中直接运行 PMD,并在编辑器中显示代码质量问题。这大大提高了开发效率和代码质量。
PMD Maven 插件
PMD Maven 插件可以在 Maven 构建过程中自动运行 PMD,并将代码质量报告集成到 Maven 的构建报告中。这使得代码质量检查成为构建流程的一部分。
通过以上模块的介绍和实践,您可以快速上手并有效使用 PMD 进行代码质量管理。
登录后查看全文
热门项目推荐
相关项目推荐
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00- QQwen3-Coder-Next2026年2月4日,正式发布的Qwen3-Coder-Next,一款专为编码智能体和本地开发场景设计的开源语言模型。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
Baichuan-M3-235BBaichuan-M3 是百川智能推出的新一代医疗增强型大型语言模型,是继 Baichuan-M2 之后的又一重要里程碑。Python00
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
项目优选
收起
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
539
3.76 K
Ascend Extension for PyTorch
Python
348
413
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
889
609
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
338
185
暂无简介
Dart
778
193
deepin linux kernel
C
27
11
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.34 K
758
React Native鸿蒙化仓库
JavaScript
303
357
openJiuwen agent-studio提供零码、低码可视化开发和工作流编排,模型、知识库、插件等各资源管理能力
TSX
986
252
仓颉编译器源码及 cjdb 调试工具。
C++
154
896