PMD (Software)

freie Software zur statischen Codeanalyse

PMD ist ein Programmierwerkzeug für die statische Codeanalyse von Quelltexten. Neben Java werden unter anderem Apex, JavaScript, XML und XSL sowie davon abgeleitete Dialekte unterstützt.[3] Der Name PMD selbst hat offiziell keine ausgeschriebene Bedeutung.[4]

PMD

Basisdaten

Hauptentwickler Andreas Dangel, Juan Martín Sotuyo Dodero, Clément Fournier
Erscheinungsjahr 4. November 2002[1]
Aktuelle Version 7.6.0[2]
(27. September 2024)
Betriebssystem plattformunabhängig
Programmier­sprache Java
Kategorie Programmierwerkzeug
Lizenz BSD-style
pmd.github.io

Fehlerkorrekturen

Bearbeiten

Die Fehler, die PMD findet, sind typischerweise keine echten Fehler, sondern eher ineffizienter Code, d. h. die Software wird in der Regel trotzdem korrekt ausgeführt, wenn die Fehler nicht korrigiert werden. PMD findet auf Basis von statischen Regeln potentielle Probleme wie beispielsweise:

  • Mögliche Bugs – Leere try/catch/finally/switch-Blöcke.
  • Toter Code – Ungenutzte Lokale Variablen, Parameter und private Methoden
  • Leere if/while-Ausdrücke
  • Überkomplizierte Ausdrücke – Unnötige if-Ausdrücke, oder for-Schleifen, die stattdessen als while-Schleifen genutzt werden könnten
  • Suboptimaler Code – verschwenderische Nutzung von String/StringBuffer
  • Klassen mit hoher Zyklomatischer Komplexität.

PMD bietet eine Vielzahl eingebauter Regeln und die Möglichkeit, vorhandene Regeln zu erweitern oder eigene Regeln zu schreiben.

Erweiterungen und Plug-ins

Bearbeiten

PMD stellt Plug-ins für Entwicklungsumgebungen wie JDeveloper, Eclipse, JBuilder, NetBeans, JCreator und IntelliJ IDEA sowie Editoren wie JEdit, Emacs und TextPad bereit.[5] Darüber hinaus existieren Erweiterungen für Build-Werkzeuge wie Apache Maven und Apache Ant, Continuous-Integration-Server wie Jenkins und Hudson sowie die statische Code-Analyse-Plattform SonarQube.

Der Copy-Paste-Detector (CPD) ist eine Erweiterung von PMD, die den Rabin-Karp-Algorithmus nutzt, um duplizierten Code zu finden. CPD kann auf Java, C, C++, C#, PHP, Ruby, Fortran, sowie JavaScript angewendet werden.[6]

Alternativen

Bearbeiten

Im Java-Umfeld werden üblicherweise neben PMD auch noch Checkstyle und FindBugs für die statische Codeanalyse verwendet. Microsoft stellt mit FxCop ein vergleichbares Werkzeug für die .NET-Plattform bereit. Siehe auch Liste von Werkzeugen zur statischen Codeanalyse.

Einzelnachweise

Bearbeiten
  1. Old Release Notes. (abgerufen am 31. März 2023).
  2. Release PMD 7.6.0 (27-September-2024). (abgerufen am 27. September 2024).
  3. Documentation Index | PMD Source Code Analyzer. pmd-code.org, abgerufen am 31. März 2023 (englisch).
  4. What does 'PMD' mean? pmd-code.org, abgerufen am 31. März 2023 (englisch).
  5. Tools / Integrations. pmd-code.org, abgerufen am 31. März 2023 (englisch).
  6. Finding duplicated code with CPD. pmd-code.org, abgerufen am 31. März 2023 (englisch).
Bearbeiten