Maison >développement back-end >Golang >Comment trouver l'index d'un élément dans une Go Slice ?

Comment trouver l'index d'un élément dans une Go Slice ?

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2024-12-11 06:48:14749parcourir

How to Find the Index of an Element in a Go Slice?

Comment trouver la position d'un élément dans Slice : limitations et solutions

Déterminer la position d'un élément dans une tranche dans Go pose un défi unique en raison du mécanisme de découpage du langage . Pour comprendre cette limitation, explorons la conception sous-jacente des tranches Go.

Contrairement aux tableaux, les tranches dans Go sont une structure de données de taille dynamique qui représente une vue dans un tableau sous-jacent plus grand. Lors de l'accès à un élément dans une tranche, Go ne conserve pas d'enregistrement explicite de l'index d'origine de l'élément dans le tableau sous-jacent. Au lieu de cela, il s'appuie sur l'index de la tranche elle-même dans le tableau.

Cette décision de conception donne la priorité à l'efficacité et aux performances de la mémoire en évitant d'avoir à stocker des informations de position redondantes pour chaque tranche. Cependant, cela présente également des défis lorsqu'on tente de déterminer la position d'un élément dans la tranche.

Approches disponibles

Malgré la limitation susmentionnée, il existe plusieurs façons d'aborder ce problème :

  1. Fonction personnalisée : Comme démontré dans l'extrait de code fourni, vous pouvez définir une fonction personnalisée qui itère à travers la tranche et renvoie la position de la valeur spécifiée. Cependant, cette approche est spécifique aux tranches int et non générique pour tout type de tranche.
  2. Itération basée sur la plage : Pour améliorer la lisibilité et la polyvalence de la fonction personnalisée, vous pouvez la réécrire en utilisant une itération basée sur la plage. Cette approche est plus flexible et vous permet d'opérer sur des tranches de n'importe quel type d'élément.
func (slice []T) pos(value T) int {
    for i, v := range slice {
        if v == value {
            return i
        }
    }
    return -1
}
  1. Tranches d'octets uniquement : Si vous traitez spécifiquement des octets tranches, Go fournit la fonction bytes.IndexByte, qui recherche efficacement la première occurrence d'une valeur d'octet spécifiée dans une tranche d'octets et renvoie sa valeur. position.

Il convient de noter que l'approche des fonctions personnalisées, bien que fonctionnelle, ne fait pas partie de la bibliothèque standard Go. Par conséquent, il est important de considérer le contexte et les exigences de votre projet spécifique avant de sélectionner une solution appropriée.

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn