Stacktrace

Als Stacktrace („Stapel(speicher)zurückverfolgung“) oder in .NET Stackwalk[1] bezeichnet man in der Informationstechnik die Ausgabe und Interpretation des Inhalts des Stacks. Ein Stacktrace wird meist zu Diagnosezwecken im Falle eines Programmabsturzes erstellt, denn damit kann die Aufrufkaskade, die zu dem Fehler führte, rekonstruiert werden.

Im Normalfall werden auf dem Stack vor allem die Rücksprungadressen der Prozeduren hinterlegt, die die jeweils nächste Prozedur aufgerufen haben. Es entsteht so eine Liste von Prozeduradressen, deren Rückverfolgung es erlaubt, den Pfad von Prozeduraufrufen vom Start des Programms bis hin zum aktuellen Zustand zu erkennen.

Besonders nützlich ist das im Fehlerfall. Eine Funktion produziert oftmals einen Fehler, wenn sie falsche Parameter erhält. Da der Programmierer aber nicht immer weiß, welche (Betriebssystem-)Funktion letzten Endes von seinem Programm aufgerufen wird, kann er anhand des Stacktraces feststellen, an welcher Stelle seines Programms eine Funktion aufgerufen wurde, die zum Fehler führte.

Aus diesem Grund wird beispielsweise unter Linux nach einer Kernelpanik standardmäßig ein Stacktrace ausgegeben.

Stacktrace in Java

In der Programmiersprache Java ist der Stacktrace fester Sprachbestandteil und mit dem Konzept der Exceptionbehandlung verbunden:

try {
  doSomething();
} catch(Exception exc) {
  exc.printStackTrace();
}

Die Ausgabe des Stacktraces sieht dann beispielsweise wie folgt aus:

java.lang.ArrayIndexOutOfBoundsException: 3
  at example.common.TestTry.execute(TestTry.java:17)
  at example.common.TestTry.main(TestTry.java:11)

Es wird also kein Hexdump mit Registerinhalten ausgegeben, sondern der Stacktrace als Text. Diese Informationen ermöglichen es dem Programmierer, einen Fehler, der während des Programmablaufs auftritt, schneller zu lokalisieren und zu beheben.

Einzelnachweise

  1. https://technet.microsoft.com/en-us/dd392323(v=vs.85).aspx?
This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. The authors of the article are listed here. Additional terms may apply for the media files, click on images to show image meta data.