Comprendre le « champ inconnu » dans les traces de pile de panique
Lors du débogage des traces de pile à partir de paniques, il est important de comprendre les différents éléments affichés. Dans l'exemple fourni :
panic: nil goroutine 1 [running]: main.F(0x1, 0x10436000) /tmp/sandbox090887108/main.go:4 +0x20 main.main() /tmp/sandbox090887108/main.go:8 +0x20
Le deuxième nombre de la ligne main.F(), 0x10436000, a intrigué certains utilisateurs. En effet, il ne suit pas le modèle attendu d'arguments transmis à la fonction.
Décodage du deuxième nombre
Les données imprimées dans la trace de la pile sont les arguments transmis à la fonction, mais les valeurs ne sont pas représentées directement. Au lieu de cela, il s’agit de données brutes imprimées sous forme de valeurs de la taille d’un pointeur. Le terrain de jeu utilisé fonctionne sur une architecture de mots de 64 bits avec des pointeurs de 32 bits (GOARCH=amd64p32).
En raison de cette configuration, vous verrez toujours un nombre pair de valeurs imprimées dans les arguments du cadre.
Tailles des pointeurs et représentation des données
La fonction main.F() n'a qu'un seul argument de type int, qui fait 4 octets de long. Cependant, la taille du pointeur est de 8 octets, ce qui signifie que la totalité du mot de 64 bits est utilisée pour contenir l'argument. Les 4 premiers octets contiennent la valeur réelle de l'argument (1 dans ce cas), et les 4 octets restants sont inutilisés.
Par conséquent, le 0x10436000 dans la trace de la pile est simplement la partie inutilisée des 64 premiers octets. petit mot.
Autres considérations
Le deuxième nombre dans la trace de la pile varie en fonction des types et du nombre d'arguments transmis à la fonction. Par exemple, si main.F() avait deux arguments de type uint8, la trace de pile afficherait :
main.F(0x97301, 0x10436000)
Dans ce cas, le 0x97301 est la valeur réelle du premier argument et le 0x10436000 est la partie inutilisée du premier mot de 64 bits, comme auparavant.
Les valeurs de retour sont également allouées sur la pile. Par exemple, si main.F() avait une signature de func F(a int64) (int, int), la trace de la pile afficherait :
main.F(0xa, 0x1054d60, 0xc420078058)
Dans ce cas, le 0xa est l'argument, et 0x1054d60 et 0xc420078058 sont les valeurs de retour.
Comprendre la représentation des arguments et des valeurs de retour dans les traces de pile de panique est crucial pour un débogage efficace.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!