Definition „Debugging Tool“

Was ist ein Debugger?

| Autor / Redakteur: chrissikraus / Stephan Augsten

Gerade bei großen Software-Projekten ist ein Debugger nahezu unabdingbar, wenn es um das Auffinden und Bereinigen von Programmierfehlern geht.
Gerade bei großen Software-Projekten ist ein Debugger nahezu unabdingbar, wenn es um das Auffinden und Bereinigen von Programmierfehlern geht. (© ribkhan - stock.adobe.com)

Der Debugger ist aus der modernen Software-Entwicklung nicht mehr wegzudenken: Er hilft dem Programmierer bei der Fehlersuche im Quellcode und erlaubt es, das Programm zur Laufzeit Schritt für Schritt zu untersuchen und dessen Ablauf zu steuern.

Selbst bei größter Sorgfalt schleichen sich beim Programmieren immer wieder Fehler in den Code ein. Mal handelt es sich um einen ungültigen Speicherzugriff, mal stimmt der Inhalt einer Variable zu einem bestimmten Zeitpunkt nicht. In einem kleinen, überschaubaren Projekt und mit genug Zeit lassen sich Bugs eventuell noch von Hand finden.

Ein komplexes Softwareprojekt kann allerdings weit mehr als eine Million Zeilen Code erreichen – der Gedanke, hier jeden noch so unscheinbaren Bug ohne maschinelle Unterstützung zu entdecken, grenzt an Wahnsinn. Erfreulicherweise gibt es ein Hilfsmittel, das Entwickler bei der Fehlersuche unterstützt: Mit dem Debugger lässt sich ein Projekt während der Laufzeit detailliert steuern und inspizieren.

Debugger unterstützen bei der Fehlersuche

In der Software-Entwicklung ist der Debugger ein essenzielles Werkzeug, das bei der Diagnose und Behebung solcher Software- und Programmierfehler hilft. Der Begriff leitet sich folgerichtig vom englischen Wort „Bug“ für Software-Fehler ab.

Sehr allgemein gesagt ist ein Debugger ein Werkzeug, das sich in einen laufenden Prozess einklinkt. So kann es beispielsweise bestimmte Vorgänge im Inneren des beobachten, zum Beispiel die Inhalte von Variablen, Speichern und Registern. Zudem können Debugger Fehlermeldungen während der Laufzeit abfangen und dem Entwickler mitteilen.

Ohne den Debugger wüsste man lediglich, dass etwas nicht so läuft wie es sollte. Bestenfalls hätte man eine dunkle Ahnung, was das Problem verursachen könnte, und könnte die entsprechenden Stellen untersuchen. Schlimmstenfalls wurde eine Klammer falsch gesetzt oder der falsche logische Operator verwendet und man müsste Stunden damit verbringen, den Code akribisch Zeichen für Zeichen zu untersuchen.

Moderne Debugger finden nicht nur Fehler im Code, sondern informieren den Entwickler auch im Detail über die Art des Fehlers und – wenn möglich – den Ort des Geschehens. Man weiß also in den meisten Fällen relativ genau, in welcher Zeile welches Problem auftritt und kann gezielt nachforschen.

Schritt für Schritt durch den Code

Eine weitere Funktion von Debuggern ist das Steuern des Programmablaufs. Bevor der Entwickler mit dem Debugging beginnt, kann er Stellen im Code definieren, an denen die Ausführung der Software pausieren soll: Breakpoints oder Haltepunkte.

Einerseits kann der Entwickler nun den genauen Zustand der Software zu diesem Zeitpunkt untersuchen. Er erhält zum Beispiel Einblick in alle Variablen und kann so prüfen, ob die erwarteten Werte vorliegen. Andererseits kann er das Programm ab dem Haltepunkt Schritt für Schritt abspielen und so exakt beobachten, was geschieht. Es wird ersichtlich, wie und wann sich die Werte einzelner Variablen verändern.

Darüber hinaus lässt sich live mitverfolgen, wie genau der Code durchlaufen wird, also in welcher Reihenfolge die einzelnen Anweisungen aufgerufen und verarbeitet werden. Diese detaillierte Analyse trägt dazu bei, die Vorgänge besser zu verstehen und so selbst komplexe Fehler zu lösen. Teils ist es auch möglich, zu vorherigen Schritten zurückzuspringen und das Programm von dort aus erneut ablaufen zu lassen.

Bedingte Haltepunkte für präzise Analysen

Haltepunkte müssen nicht allgemeingültig sein. Viele Debugger bieten die Möglichkeit, einen Breakpoint mit Bedingungen auszustatten. So kann erreicht werden, dass das Programm nur in einer vordefinierten Situation anhält. Beispiel: Erst beim 32. Durchlauf einer Schleife tritt ein Fehler auf; statt also 31 ereignislose Wiederholungen schrittweise zu durchlaufen, lässt man das Programm direkt vor der sehenswerten Iteration anhalten und kann umgehend in den Fehlerfall einsteigen.

Software zur Laufzeit manipulieren

Außerdem können viele Debugger im laufenden Betrieb bestimmte Werte vortäuschen, um das Verhalten des Programms beispielsweise mit veränderten Variablen beobachten zu können. Ebenso gibt es Debugger, die Änderungen am Quellcode während der Laufzeit verarbeiten können. Das bedeutet, dass das Programm nicht angehalten und neu gestartet werden muss, um die Auswirkung einer veränderten Zeile Code zu beobachten. Stattdessen kann der Programmablauf per Debugger pausiert werden, während man die Änderungen vornimmt.

Kommentare werden geladen....

Kommentar zu diesem Artikel

Der Kommentar wird durch einen Redakteur geprüft und in Kürze freigeschaltet.

Anonym mitdiskutieren oder einloggen Anmelden

Avatar
Zur Wahrung unserer Interessen speichern wir zusätzlich zu den o.g. Informationen die IP-Adresse. Dies dient ausschließlich dem Zweck, dass Sie als Urheber des Kommentars identifiziert werden können. Rechtliche Grundlage ist die Wahrung berechtigter Interessen gem. Art 6 Abs 1 lit. f) DSGVO.
  1. Avatar
    Avatar
    Bearbeitet von am
    Bearbeitet von am
    1. Avatar
      Avatar
      Bearbeitet von am
      Bearbeitet von am

Kommentare werden geladen....

Kommentar melden

Melden Sie diesen Kommentar, wenn dieser nicht den Richtlinien entspricht.

Kommentar Freigeben

Der untenstehende Text wird an den Kommentator gesendet, falls dieser eine Email-hinterlegt hat.

Freigabe entfernen

Der untenstehende Text wird an den Kommentator gesendet, falls dieser eine Email-hinterlegt hat.

Aktuelle Beiträge zu diesem Thema

DevOps und „Shift left“ in drei Schritten

Agile Entwicklung erfordert Continuous Testing

DevOps und „Shift left“ in drei Schritten

Durch „Shift Left“ rückt das Testen auf dem Zeitstrahl des Software Development Lifecycle weiter nach links. Warum der Begriff bei DevOps und agiler Entwicklung aber etwas irreführend ist und was Unternehmen tun müssen, erläutert Malcom Isaacs von Micro Focus. lesen

DevTools von Firefox 65 bringen neue Funktionen

Flexbox Inspector vereinfacht CSS- und JavaScript-Entwicklung

DevTools von Firefox 65 bringen neue Funktionen

Mit der neuen Version 65 des Webbrowsers Firefox bekommen auch Entwickler über die neue Version DevTools einige Unterstützung. Dazu gehört zum Beispiel der Flexbox Inspector, der beim Umgang mit CSS-Layouts hilft. lesen

Visual Studio Code und Atom unter Windows

Beliebte Code-Editoren, Teil 1

Visual Studio Code und Atom unter Windows

Zum Programmieren benötigt man zwei Dinge: Die Fähigkeit zu entwickeln und die bestmöglichen Werkzeuge dafür. Bei den Code-Editoren sind die Unterschiede zwischen guten und schlechten Tools aber nicht so leicht auszumachen. lesen

Mehr Sicherheit in Swift 5

Geschützte Variablen und weitere Neuerungen

Mehr Sicherheit in Swift 5

Mit der Programmiersprache Swift 5 verbessert Apple auch die Sicherheit des Speichers, indem der Zugriff auf Variablen während einer Änderung blockiert wird. Das soll vor allem die Stabilität verbessern. lesen

Azure wird zur Multifunktionsplattform

Blockchain, DevOps, GitHub und Open Source

Azure wird zur Multifunktionsplattform

Ursprünglich stand bei der Cloud-Computing-Plattform Microsoft Azure das Computing im Fokus. Neue Möglichkeiten in den Bereichen Bitcoin und DevOps sowie der Übernahme von GitHub gibt es nun ganz neue Möglichkeiten für Unternehmen und Entwickler, Dienste auszulagern. lesen

Programmieren mit Notepad++

Erweiterbarer Texteditor unter Windows

Programmieren mit Notepad++

Das Notepad++ ist ein mächtiger Texteditor. Dabei bietet das Tool Syntax Highlighting und weitere Entwickler-Funktionen und lässt sich als Open-Source-Software um zusätzliche Sprachen und Plugins bis hin zur vollständigen IDE erweitern. lesen

Was tut sich bei DevOps, Blockchain und Java?

Red Hat Predictions 2019

Was tut sich bei DevOps, Blockchain und Java?

Was bringt das neue Jahr für Programmierer und das Software Development? Für die Bereiche Entwickler und DevOps, Java sowie Blockchain haben sich Experten von Red Hat darüber Gedanken gemacht und einige Prognosen abgegeben. lesen

Was ist Exception Handling?

Definition „Ausnahmebehandlung“

Was ist Exception Handling?

In einigen Fällen werden Programme mit Ausnahmen von den Instruktionen konfrontiert. Entwickler integrieren Exception Handler in den Code, damit nicht jede Abweichung von den Instruktionen sofort zum Fehlercode führt. lesen

Entwicklertools, Open Source und Serverless im Fokus

Microsoft Connect(); 2018

Entwicklertools, Open Source und Serverless im Fokus

Auf der Microsoft Connect(); 2018 standen neue Entwicklertools, Open-Source-Projekte und Serverless-Computing-Fähigkeiten im Fokus. Damit sollen Entwickler die Möglichkeit erhalten, Software besser und unkomplizierter zu schreiben. lesen

copyright

Dieser Beitrag ist urheberrechtlich geschützt. Sie wollen ihn für Ihre Zwecke verwenden? Infos finden Sie unter www.mycontentfactory.de (ID: 45385542 / Definitionen)