Tutorial:Programmieren mit Python/Debugging: Unterschied zwischen den Versionen
Sn (Diskussion | Beiträge) (Icons) |
Sn (Diskussion | Beiträge) (Allgemeine Infos in Inhaltsseite ausgelagert.) |
||
(4 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt) | |||
Zeile 1: | Zeile 1: | ||
{{../Navigation}} | |||
Thonny verfügt über einen eingebauten [[Debugging|Debugger]] mit recht simpler Funktionalität, der aber für die meisten schulischen Zwecke genügt. | |||
Thonny verfügt über einen eingebauten Debugger mit recht simpler Funktionalität, der aber für die meisten schulischen Zwecke genügt. | |||
Die Tastenkombination {{Tastatur|ShiftF5}} oder das Icon mit dem Käfer [[Datei:Thonny debugger.png|x12px]] starten den Debugger. Im Debug-Modus stehen dann diverse Werkzeuge zur Verfügung, um das Programm kontrolliert und schrittweise ablaufen zu lassen. | Die Tastenkombination {{Tastatur|ShiftF5}} oder das Icon mit dem Käfer [[Datei:Thonny debugger.png|x12px]] starten den Debugger. Im Debug-Modus stehen dann diverse Werkzeuge zur Verfügung, um das Programm kontrolliert und schrittweise ablaufen zu lassen. | ||
Zeile 19: | Zeile 15: | ||
!Erläuterung | !Erläuterung | ||
|- | |- | ||
|[[Datei:Thonny debug skip.png|x12px]] | |[[Datei:Thonny debug skip.png|x12px]] Einzelschritt | ||
Einzelschritt | |||
|Die hervorgehobene Zeile wird vollständig ausgeführt und zur nächsten auszuführenden Zeile gesprungen. | |Die hervorgehobene Zeile wird vollständig ausgeführt und zur nächsten auszuführenden Zeile gesprungen. | ||
|- | |- | ||
|[[Datei:Thonny debug enter.png|x12px]] | |[[Datei:Thonny debug enter.png|x12px]] Eintreten | ||
Eintreten | |||
|Komplexere Anweisungen werden so kleinschrittig wie möglich abgearbeitet. | |Komplexere Anweisungen werden so kleinschrittig wie möglich abgearbeitet. | ||
|- | |- | ||
|[[Datei:Thonny debug leave.png|x12px]] | |[[Datei:Thonny debug leave.png|x12px]] Verlassen | ||
Verlassen | |||
|Es wird ans Ende der schrittweisen Ausführung einer komplexen Anweisung gesprungen. | |Es wird ans Ende der schrittweisen Ausführung einer komplexen Anweisung gesprungen. | ||
|- | |- | ||
|[[Datei:Thonny debug resume.png|x12px]] | |[[Datei:Thonny debug resume.png|x12px]] Fortfahren | ||
Fortfahren | |||
|Der Programmablauf wird normal bis zum nächsten Breakpoint bzw. falls es keinen gibt, zum Programmende fortgeführt. | |Der Programmablauf wird normal bis zum nächsten Breakpoint bzw. falls es keinen gibt, zum Programmende fortgeführt. | ||
|- | |- | ||
|[[Datei:Thonny debug run to cursor.png|x12px]] | |[[Datei:Thonny debug run to cursor.png|x12px]] Bis zum Cursor ausführen | ||
Bis zum Cursor ausführen | |||
|Der Programmablauf wird bis zur Position des Textcursors im Programmcode fortgeführt. | |Der Programmablauf wird bis zur Position des Textcursors im Programmcode fortgeführt. | ||
|- | |- | ||
Zeile 47: | Zeile 33: | ||
|Es wird einen Schritt im Programmablauf zurückgesprungen. | |Es wird einen Schritt im Programmablauf zurückgesprungen. | ||
|} | |} | ||
Beim ''Eintreten'' geht der Debugger so kleinschrittig wie möglich vor. Die folgenden elf Screenshots illustrieren, wie eine Benutzereingabe Schritt für Schritt vom Debugger verarbeitet wird, bis am Ende die Eingabe in der Variablen | Beim ''Eintreten'' geht der Debugger so kleinschrittig wie möglich vor. Die folgenden elf Screenshots illustrieren, wie eine Benutzereingabe Schritt für Schritt vom Debugger verarbeitet wird, bis am Ende die Eingabe in der Variablen {{Python|startwert}} gespeichert worden ist:<gallery mode="slideshow"> | ||
Datei:Thonny debug 1.png|Schritt 1 | Datei:Thonny debug 1.png|Schritt 1 | ||
Datei:Thonny debug 2.png|Schritt 2 | Datei:Thonny debug 2.png|Schritt 2 |
Aktuelle Version vom 6. November 2024, 19:24 Uhr
Thonny verfügt über einen eingebauten Debugger mit recht simpler Funktionalität, der aber für die meisten schulischen Zwecke genügt.
Die Tastenkombination ShiftF5 oder das Icon mit dem Käfer starten den Debugger. Im Debug-Modus stehen dann diverse Werkzeuge zur Verfügung, um das Programm kontrolliert und schrittweise ablaufen zu lassen.
Eins der wichtigsten Werkzeuge sind Breakpoints. Breakpoints können gezielt platziert werden, um den Programmfluss an einer bestimmten Stelle zu unterbrechen und die weitere Ausführung der Kontrolle des Entwicklys zu überlassen.
Einen Breakpoint kann man mit einem Klick auf die Zeilennummer derjenigen Anweisung setzen, an der der Programmablauf unterbrochen werden soll. Neben dieser Zeilennummer erscheint dann ein roter Punkt .
Sobald der Programmablauf beim Debuggen einen Breakpoint erreicht, wird er gestoppt, die aktuell betrachtete Programmzeile farblich hervorgehoben und das weitere Vorgehen dem Debuggy überlassen. Falls keine Breakpoints gesetzt sind, wird von Anfang an so verfahren.
Für das weitere Vorgehen stehen folgende Werkzeuge zur Verfügung, die entweder über die Icon-Symbolleiste oder das “Ausführen”-Menü zu erreichen sind:
Beim Eintreten geht der Debugger so kleinschrittig wie möglich vor. Die folgenden elf Screenshots illustrieren, wie eine Benutzereingabe Schritt für Schritt vom Debugger verarbeitet wird, bis am Ende die Eingabe in der Variablen startwert
gespeichert worden ist:
Insbesondere bei der Auswertung von komplexeren Ausdrücken, die nur in einigen Fällen Fehler produzieren, kann es hilfreich sein, sich nach jedem kleinsten Schritt des gegenwärtigen Zwischenstandes der Ausführung bewusst zu sein.
Besonders hilfreich ist hierbei das andockbare Variablen-Fenster. In diesem Fenster kann der Inhalt aller verwendeten Variablen eines Programms eingesehen werden. Dies funktioniert jedoch nur, wenn der Programmablauf angehalten ist; während z.B. eine besonders lange Wiederholung läuft, zeigt das Variablenfenster keine Änderungen an. In diesem Fall muss der Debugger benutzt werden, um den Ablauf der Wiederholung Schritt für Schritt nachvollziehen zu können.