Heim > Artikel > Backend-Entwicklung > Welche Bedeutung hat das „Unbekannte Feld“ in einem Go-Panic-Stack-Trace und wie können wir die Argumente im Traceback entschlüsseln?
Die Begegnung mit dem rätselhaften „Unbekanntes Feld in Panic Stack Trace“ ist beim Debuggen von Panic-Fehlern in Go keine Seltenheit. Um dieses Rätsel zu lösen, tauchen wir in die Komplexität von Stack-Traces ein.
Im bereitgestellten Code-Snippet:
package main func F(a int) { panic(nil) } func main() { F(1) }
Beim Ausführen des Programms wird ein Panic-Stack-Trace angezeigt:
panic: nil goroutine 1 [running]: main.F(0x1, 0x10436000) /tmp/sandbox090887108/main.go:4 +0x20 main.main() /tmp/sandbox090887108/main.go:8 +0x20
Welche Bedeutung hat der kryptische Wert 0x10436000, der neben F(0x1) erwähnt wird?
Der Wert 0x10436000 ist kein zweites Argument der Funktion. Stattdessen stellt es die als erstes Argument übergebenen Rohdatenwerte dar, ausgedrückt als Werte in Zeigergröße. Dies ist ein Ergebnis der Playground-Architektur, die eine 64-Bit-Wortgröße, aber 32-Bit-Zeiger (GOARCH=amd64p32) bietet.
In der Datei „traceback.go“ wird die Werte werden gedruckt, indem iterativ auf die Argumente basierend auf ihrer Zeigergröße zugegriffen wird:
for i := uintptr(0); i < frame.arglen/sys.PtrSize; i++ {
Das bedeutet, dass Wertepaare in den Argumenten jedes Frames gedruckt werden, da die Wortgröße doppelt so groß ist wie die Zeigergröße im Playground.
Zur weiteren Veranschaulichung:
func F(a uint8) { panic(nil) }
Aufruf von F(1)-Ergebnissen in:
main.F(0x97301, 0x10436000)
Nur die ersten 8 Bits des 64-Bit-Worts werden verwendet (1 in diesem Fall), während der Rest ungenutzt bleibt.
main.F(0x100000001, 0xc400000001)
Die drei Argumente belegen zwei Wörter und die zusätzlichen nicht verwendeten Werte werden gedruckt.
func F(a int64) (int, int)
Auf amd64 würden die Stapelrahmenargumente wie folgt aussehen:
main.F(0xa, 0x1054d60, 0xc420078058)
Das erste Wort ist für das Argument, während die anderen beiden für die nicht initialisierten Rückgabewerte gelten.
Das obige ist der detaillierte Inhalt vonWelche Bedeutung hat das „Unbekannte Feld“ in einem Go-Panic-Stack-Trace und wie können wir die Argumente im Traceback entschlüsseln?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!