Maison >développement back-end >Golang >Pourquoi est-ce que j'obtiens « panique : erreur d'exécution : index hors plage » même si ma tranche Go a une capacité non nulle ?
Dépannage "panique : erreur d'exécution : index hors plage" lorsque la longueur du tableau n'est pas nulle
En Go, lorsque vous travaillez avec des tableaux ou tranches, il est crucial de comprendre le concept de longueur et de capacité. Dans l'extrait de code donné, le problème vient de l'initialisation du tableau de résultats à l'aide de make([]string, 0, 4).
Comprendre le rôle de make([]string, 0, 4)
make([]string, 0, 4) crée une tranche de type []string avec une longueur initiale de 0 et une capacité de 4. La capacité définit le nombre maximum d'éléments pouvant être stockés dans la tranche sans réallocation de mémoire.
Distinction entre longueur et capacité
La longueur indique le nombre d'éléments actuellement présents dans la tranche, tandis que la capacité représente la taille maximale qu'elle peut contenir . Si la tranche contient déjà suffisamment d’éléments, l’ajout d’éléments supplémentaires dans la capacité n’entraînera pas de réallocation. Cependant, le dépassement de la capacité déclenchera une réallocation, qui implique la création d'un nouveau tableau sous-jacent et la copie des éléments existants.
Dans votre code, make([]string, 0, 4) initialise une tranche vide avec une capacité de 4. Tenter d'accéder à des éléments au-delà de la longueur actuelle (index 0) entraînera une erreur d'exécution car il n'y a aucun élément à cet index.
Résoudre le problème
L'erreur peut être résolue soit en initialisant la tranche avec une longueur initiale suffisante, soit en utilisant append pour agrandir dynamiquement la tranche si nécessaire.
Option 1 : initialiser avec une longueur suffisante
Si vous connaissez le nombre approximatif d'éléments qui seront stockés dans la tranche, vous pouvez l'initialiser avec une longueur appropriée. Par exemple, result := make([]string, 4) initialise une tranche d'une longueur et d'une capacité de 4.
Option 2 : Utiliser Append
Append ajoute éléments à la fin d’une tranche. Si la tranche a une capacité suffisante, elle est retranchée pour accueillir les nouveaux éléments. Sinon, un nouveau tableau sous-jacent est alloué. En utilisant append à plusieurs reprises, vous pouvez agrandir progressivement la tranche selon vos besoins sans vous soucier de dépasser la capacité.
Code simplifié utilisant Append
Voici une version simplifiée de votre code utilisant ajouter :
<code class="go">package main import ( "fmt" "strings" ) func main() { strs := strings.Fields("Political srt") var result []string for _, s := range strs { if strings.ContainsAny(s, "eaiu") { result = append(result, s) } } fmt.Println(result) }</code>
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!